:root {
  --blue: #0345c4;
  --blue-deep: #0340bb;
  --cta-blue: #014cb3;
  --green: #0a8a30;
  --green-dark: #06702a;
  --yellow: #ffbe13;
  --kakao: #fed900;
  --navy: #14366e;
  --logo-navy: #0a2398;
  --ink: #101b2b;
  --muted: #5f6b7a;
  --line: #dfe7f3;
  --soft: #f4f9ff;
  --card: #ffffff;
  --shadow: 0 18px 45px rgba(19, 60, 117, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Noto Sans KR", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #f7fbff 0, #fff 420px);
}
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
[hidden] { display: none !important; }
.m-only { display: none; }

/* ───── header ───── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  height: 66px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
  padding: 0 36px;
  background: rgba(255, 255, 255, .96);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}
.brand { display: flex; align-items: center; min-width: 0; }
.brand-logo { height: 48px; width: auto; display: block; }
.brand-main {
  color: var(--logo-navy);
  font-size: 25px;
  font-weight: 900;
  white-space: nowrap;
}
.brand-main b,
.brand-main .rental { color: #068021; }
.brand-sub { margin-top: 4px; font-size: 13px; color: var(--logo-navy); font-weight: 700; }
.desktop-nav {
  flex: 1;
  display: flex;
  justify-content: center;
  gap: clamp(16px, 2.8vw, 52px);
  font-size: 16.5px;
  font-weight: 700;
  color: #1b2a42;
}
.desktop-nav a { padding: 22px 0; border-bottom: 3px solid transparent; white-space: nowrap; }
.desktop-nav a:hover { color: var(--blue); border-color: var(--blue); }
.header-actions { display: flex; align-items: center; gap: 18px; flex-shrink: 0; }
.phone { display: flex; align-items: center; gap: 10px; white-space: nowrap; }
.phone-ico { width: 26px; height: 26px; color: #0d1726; }
.phone strong {
  display: block;
  color: #00911f;
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .5px;
}
.phone small { display: block; color: #4c5565; font-size: 12px; font-weight: 600; margin-top: 5px; }
.quick-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 154px;
  height: 46px;
  padding: 0 22px;
  color: #fff;
  background: #078d2c;
  border-radius: 999px;
  font-weight: 900;
  white-space: nowrap;
  box-shadow: 0 10px 25px rgba(7, 141, 44, .25);
}
.quick-btn svg { width: 18px; height: 18px; }
.menu-btn { display: none; border: 0; background: transparent; color: #122036; padding: 4px; cursor: pointer; }
.menu-btn svg { width: 26px; height: 26px; display: block; }
.site-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 14px;
  z-index: 95;
}
.menu-card {
  display: grid;
  min-width: 218px;
  padding: 8px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 22px 50px rgba(13, 36, 70, .2);
}
.site-menu a {
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 800;
  color: #1b2a42;
}
.site-menu a:hover { background: #f1f6ff; color: var(--blue); }
.site-menu .menu-call {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  justify-content: center;
  background: linear-gradient(135deg, #14a04a, #0a8a3a);
  color: #fff;
}
.site-menu .menu-call:hover { background: linear-gradient(135deg, #129546, #097c34); color: #fff; }
.site-menu .menu-call svg { width: 17px; height: 17px; }

/* ───── hero ───── */
.hero {
  position: relative;
  min-height: 520px;
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(420px, 1fr) 250px;
  gap: 20px;
  align-items: center;
  padding: 28px 70px 24px;
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, #fdfeff, #f2f8fe);
  z-index: -2;
}
/* 고정 크기 — 좁아지면 축소 대신 숨김 (운영자 지시) */
.hero-photo {
  position: absolute;
  bottom: 0;
  right: 652px;
  width: 612px;
  height: auto;
  z-index: -1;
}
@media (max-width: 1659px) {
  .hero-photo { display: none; }
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 120px;
  background: linear-gradient(180deg, rgba(255,255,255,0), #f7fbff 85%);
  z-index: -1;
}
.hero-copy { max-width: 640px; }
.hero-copy h1 {
  margin: 0 0 18px;
  font-size: clamp(48px, 4.6vw, 72px);
  line-height: 1.12;
  font-weight: 900;
  letter-spacing: -1px;
}
.hero-copy h1 em { color: #0040c5; font-style: normal; }
.hero-copy p {
  margin: 0 0 30px;
  font-size: 20px;
  color: #243246;
  font-weight: 600;
}
.hero-badges { display: flex; flex-wrap: wrap; gap: 14px 24px; max-width: 470px; }
.hero-badges span {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 10px;
  align-items: center;
  font-size: 16px;
  font-weight: 900;
  white-space: nowrap;
}
.hero-badges b {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: #fff;
  background: var(--yellow);
  font-size: 19px;
  font-weight: 900;
}
.hero-badges b svg { width: 21px; height: 21px; }
.hero-badges .i-gift { background: #18a047; }
.hero-badges .i-as { background: #2a7df0; }
.hero-badges small {
  grid-column: 2;
  display: block;
  color: var(--muted);
  font-size: 13.5px;
  font-weight: 600;
}
.hero-contact { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 30px; }
.call-card, .kakao-card {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 208px;
  height: 70px;
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--shadow);
}
.call-card { gap: 13px; padding: 0 28px; }
.call-card svg { width: 23px; height: 23px; color: var(--blue); flex-shrink: 0; }
.call-card span { display: grid; gap: 2px; }
.call-card small { display: block; color: var(--muted); font-size: 11px; font-weight: 700; letter-spacing: .2px; }
.call-card strong { display: block; color: var(--blue); font-size: 21px; line-height: 1.05; font-weight: 900; letter-spacing: .3px; }
.call-card .hours { font-size: 9.5px; color: #8b96a6; }
.kakao-card {
  gap: 10px;
  min-width: 200px;
  padding: 0 26px;
  color: #1a1604;
  background: var(--kakao);
  font-size: 16px;
  font-weight: 900;
  box-shadow: 0 14px 30px rgba(254, 217, 0, .35);
}
.kakao-card img { width: 30px; height: 30px; border-radius: 8px; }

/* ───── quote card ───── */
.quote-card {
  scroll-margin-top: 90px;
  grid-column: 2;
  justify-self: end;
  width: min(430px, 100%);
  padding: 26px 28px;
  margin-top: 24px;
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(211,225,245,.9);
  border-radius: 26px;
  box-shadow: var(--shadow);
}
.quote-title h2 { margin: 0 0 20px; font-size: 25px; font-weight: 900; }
.quote-title h2 b { color: var(--blue); font-size: 30px; }
.quote-title ol {
  display: flex;
  justify-content: space-between;
  padding: 0 6px;
  margin: 0 0 22px;
  list-style: none;
}
.quote-title li {
  position: relative;
  flex: 1;
  display: grid;
  justify-items: center;
  gap: 9px;
  color: #243246;
  font-size: 14px;
  font-weight: 800;
}
.quote-title li.active { color: var(--blue); }
.quote-title li + li::before {
  content: "";
  position: absolute;
  top: 22px;
  right: calc(50% + 32px);
  left: calc(-50% + 32px);
  border-top: 2px dashed #c7d3e4;
}
.quote-title li + li::after {
  content: "";
  position: absolute;
  top: 18px;
  right: calc(50% + 27px);
  border: 5px solid transparent;
  border-left: 7px solid #b9c8dd;
}
.step-ico {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
}
.step-ico svg { width: 24px; height: 24px; }
.ico-print {
  color: #fff;
  background: linear-gradient(135deg, #1d72f5, #0d52d8);
  box-shadow: 0 8px 16px rgba(13, 82, 216, .28);
}
.ico-doc {
  color: #00841d;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 6px 14px rgba(31, 58, 91, .1);
}
.ico-check {
  color: #fff;
  background: var(--yellow);
  box-shadow: 0 8px 16px rgba(255, 190, 19, .32);
}
.quote-card fieldset {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  gap: 9px 10px;
  padding: 0;
  margin: 0 0 14px;
  border: 0;
}
.quote-card fieldset.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.quote-card fieldset.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.quote-card legend {
  padding: 0;
  margin-bottom: 7px;
  font-size: 14px;
  font-weight: 900;
}
.quote-card label {
  position: relative;
  display: block;
  height: 44px;
  cursor: pointer;
}
/* 라디오만 숨김 — input 전체를 잡으면 .q-phone/.q-etc까지 absolute+투명이 되어
   전화칸 실종 + 가로 오버플로(좌측 시프트) 사고가 남 (2026-06-11 실발생) */
.quote-card input[type="radio"] { position: absolute; opacity: 0; }
.q-opts label.span2 { grid-column: 1 / -1; }
.quote-card label span {
  display: grid;
  place-items: center;
  height: 100%;
  color: #1b2737;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-weight: 900;
}
.quote-card input:checked + span {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(180deg, #0357dc, #0340bb);
  box-shadow: inset 0 -2px 4px rgba(0,0,0,.12);
}
.q-q { margin: 2px 0 12px; font-size: 17px; font-weight: 900; color: #15233c; }
.q-opts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.q-opts label { position: relative; display: block; height: 50px; cursor: pointer; }
.q-opts.big label { height: 58px; }
.q-opts.big span { font-size: 17px; }
.q-etc-row { display: flex; gap: 8px; margin-top: 10px; }
.q-etc {
  flex: 1;
  height: 50px;
  padding: 0 16px;
  border: 1.5px solid var(--line);
  border-radius: 13px;
  font-size: 15px;
  font-weight: 700;
}
.q-etc:focus { outline: none; border-color: var(--blue); }
.q-etc-next {
  flex: 0 0 auto;
  padding: 0 20px;
  border: 0;
  border-radius: 13px;
  background: linear-gradient(180deg, #14a04a, #0a8a3a);
  color: #fff;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
}
.q-phone {
  width: 100%;
  height: 56px;
  padding: 0 18px;
  border: 1.5px solid var(--line);
  border-radius: 14px;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: .5px;
  color: #15233c;
}
.q-phone:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(3, 69, 196, .12); }
.q-error { margin: 8px 2px 0; color: #d2372e; font-size: 13px; font-weight: 700; }
.q-extra { margin-top: 14px; border: 1px solid #e7edf6; border-radius: 14px; padding: 4px 14px; background: #fafcff; }
.q-extra summary {
  cursor: pointer;
  padding: 10px 2px;
  font-size: 13.5px;
  font-weight: 800;
  color: #57637a;
}
.q-extra[open] summary { color: var(--blue); }
.q-extra fieldset { margin: 0 0 12px; }
.q-extra legend { font-size: 13px; }
.q-extra label { height: 40px; }
.q-extra label span { font-size: 13.5px; }
.q-hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.q-submit { margin-top: 14px; }
.q-submit:disabled { opacity: .65; cursor: wait; }
.q-done-ico {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  margin: 2px 0 0;
  border-radius: 50%;
  background: linear-gradient(180deg, #14a04a, #0a8a3a);
  color: #fff;
  box-shadow: 0 12px 25px rgba(18, 147, 66, .25);
}
.q-done-ico svg { width: 28px; height: 28px; }
.q-alt { margin: 4px 0 0; color: #74819a; font-size: 12.5px; font-weight: 700; }
.q-nav { display: flex; gap: 10px; margin-top: 10px; }
.q-prev {
  flex: 0 0 auto;
  height: 58px;
  padding: 0 18px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: #fff;
  color: #445163;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
}
.primary-submit {
  flex: 1;
  width: 100%;
  height: 58px;
  border: 0;
  border-radius: 15px;
  color: #fff;
  background: linear-gradient(180deg, #14a04a, #0a8a3a);
  font-size: 20px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 12px 25px rgba(18, 147, 66, .23);
}
.primary-submit span { float: right; margin-right: 12px; }
.q-hint { margin: 2px 0 0; color: #7c8798; font-size: 12px; font-weight: 600; }
.q-result { display: grid; gap: 12px; }
.q-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.q-summary li {
  padding: 6px 12px;
  background: #eef4ff;
  border-radius: 999px;
  color: #0c3eb0;
  font-size: 12.5px;
  font-weight: 800;
}
.q-est {
  display: grid;
  gap: 4px;
  padding: 14px 16px 12px;
  background: #f3f8ff;
  border: 1px solid #d9e7fb;
  border-radius: 14px;
}
.q-est small { color: #57637a; font-size: 12px; font-weight: 800; }
.q-est-range { color: #0c3eb0; font-size: 24px; font-weight: 900; letter-spacing: -.4px; }
.q-est p { margin: 0; font-size: 12.5px; font-weight: 700; color: #2b3a52; }
.q-est-pick { color: #0a6b2e !important; }
.q-est-note { color: #6b7787 !important; font-weight: 600 !important; }
.q-est-disc { color: #93a0b2 !important; font-size: 11px !important; font-weight: 600 !important; margin-top: 2px !important; }
.q-msg { margin: 4px 0 2px; font-size: 15px; line-height: 1.5; color: #243246; font-weight: 600; }
.q-msg b { font-size: 17px; color: #0c3eb0; }
.q-call {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 58px;
  border-radius: 15px;
  background: linear-gradient(180deg, #14a04a, #0a8a3a);
  color: #fff;
  font-size: 19px;
  font-weight: 900;
  box-shadow: 0 12px 25px rgba(18, 147, 66, .23);
}
.q-call svg { width: 22px; height: 22px; }
.q-kakao {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  height: 52px;
  border-radius: 15px;
  background: var(--kakao);
  color: #1a1604;
  font-size: 16px;
  font-weight: 900;
}
.q-kakao img { width: 24px; height: 24px; border-radius: 6px; }
.q-reset {
  border: 0;
  background: transparent;
  color: #8b96a6;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: underline;
  cursor: pointer;
}
.quote-card.flash { animation: q-flash 1.2s ease 2; }
@keyframes q-flash {
  0%, 100% { box-shadow: var(--shadow); }
  50% { box-shadow: 0 0 0 5px rgba(20, 160, 74, .45), var(--shadow); }
}

/* ───── 서브페이지 공통 ───── */
.desktop-nav a.on { color: var(--blue); border-color: var(--blue); }
.page-head {
  padding: 38px 0 26px;
  background: linear-gradient(180deg, #eef6ff, #fdfeff);
  border-bottom: 1px solid var(--line);
}
.page-head .wrap, .page-body { width: min(1200px, calc(100% - 48px)); margin: 0 auto; }
.page-head h1 { margin: 0 0 8px; font-size: 30px; letter-spacing: -.4px; }
.page-head p { margin: 0; color: var(--muted); font-weight: 600; }
.page-body { padding: 28px 0 64px; display: grid; gap: 30px; }
.pg-sec h2 { margin: 0 0 12px; font-size: 21px; letter-spacing: -.3px; }
.pg-sec h2 em { font-style: normal; color: #8b96a6; font-size: 14px; font-weight: 800; margin-left: 6px; }
.pg-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px 24px;
  box-shadow: 0 8px 22px rgba(35, 88, 148, .05);
}
.pg-lead { margin: 0; font-size: 15.5px; line-height: 1.75; color: #243246; font-weight: 500; }
.pg-lead b { color: #0c3eb0; }
.pg-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; }
.pg-grid .pg-card { display: grid; gap: 6px; padding: 18px 20px; }
.pg-grid .pg-card b { font-size: 15.5px; }
.pg-grid .pg-card span { color: var(--muted); font-size: 13px; font-weight: 600; line-height: 1.5; }
.pg-strong { color: #0c3eb0; font-weight: 900; }
.pg-note { margin: 10px 2px 0; color: #8b96a6; font-size: 12.5px; font-weight: 600; }
.compare-note-card { display: grid; gap: 18px; background: linear-gradient(180deg, #fff, #f8fbff); }
.compare-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.compare-points article {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid #e1eaf7;
  border-radius: 14px;
  background: #fff;
}
.compare-points b { color: var(--blue); font-size: 15px; font-weight: 900; }
.compare-points span { color: #53637a; font-size: 13px; font-weight: 700; line-height: 1.55; }
.trust-mini-grid .pg-card { border-color: #dfeaf8; background: #f8fbff; }
.trust-mini-grid .pg-card b { color: #0c3eb0; }

.naver-map-card {
  display: grid;
  gap: 16px;
  padding: 0;
  overflow: hidden;
}
.map-copy { padding: 22px 24px 0; }
.map-note { margin: 6px 0 0; color: var(--muted); font-size: 13px; font-weight: 700; }
.naver-map-canvas {
  position: relative;
  width: 100%;
  min-height: 360px;
  overflow: hidden;
  background: #eef4ff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.map-pending {
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  gap: 8px;
  padding: 24px;
  text-align: center;
  color: #536174;
  background: linear-gradient(135deg, #f5f9ff, #eef6ff);
}
.map-pending b { color: #10223e; font-size: 16px; }
.map-pending span { max-width: 360px; font-size: 13px; font-weight: 700; line-height: 1.55; }
.map-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0 24px 22px;
}
.map-actions .pg-link-btn { margin-top: 0; }
.map-actions .pg-link-btn.ghost {
  color: #0a8a30;
  background: #effaf3;
  border: 1px solid #d9f0e2;
  box-shadow: none;
}
.naver-map-card.is-map-ready .map-pending { display: none; }
.naver-map-card.is-map-error .map-pending b { color: #9b1c1c; }
.naver-map-info {
  display: grid;
  gap: 4px;
  min-width: 190px;
  padding: 4px 2px;
  color: #14233c;
  font-family: "Noto Sans KR", sans-serif;
}
.naver-map-info b { font-size: 14px; font-weight: 900; }
.naver-map-info span { font-size: 12px; font-weight: 700; color: #536174; }
.naver-map-info a { margin-top: 3px; color: #03a84c; font-size: 12px; font-weight: 900; }

/* ── 문의 채널 카드 (전화/카카오/플레이스/메일/팩스 — 채널 브랜드 컬러 + 카드 전체 버튼) ── */
.contact-cards { gap: 14px; }
.contact-card {
  display: grid;
  gap: 5px;
  align-content: start;
  padding: 22px 22px 18px;
  border-radius: 18px;
  border: 1px solid transparent;
  transition: transform .15s ease, box-shadow .15s ease;
}
a.contact-card:hover { transform: translateY(-3px); box-shadow: 0 16px 32px rgba(25, 56, 102, .15); }
.contact-card i {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 6px;
  border-radius: 13px;
}
.contact-card i svg { width: 22px; height: 22px; }
.contact-card b { font-size: 14px; font-weight: 800; opacity: .85; }
.contact-card strong { font-size: 19px; font-weight: 900; letter-spacing: -.2px; }
.contact-card span { font-size: 12.5px; font-weight: 600; opacity: .75; line-height: 1.5; }
.contact-card em { margin-top: 9px; font-style: normal; font-size: 13px; font-weight: 900; }
.ch-tel { background: #effaf3; border-color: #d9f0e2; color: #123a22; }
.ch-tel i { background: #0a8a3a; color: #fff; }
.ch-tel strong, .ch-tel em { color: #0a8a3a; }
.ch-kakao { background: #fee500; border-color: #f4d900; color: #191919; }
.ch-kakao i { background: #3c1e1e; color: #fee500; }
.ch-kakao strong { color: #191919; }
.ch-kakao em { color: #3c1e1e; }
.ch-place { background: #eafaf1; border-color: #cdf0dd; color: #0b3322; }
.ch-place i { background: #03c75a; color: #fff; }
.ch-place strong, .ch-place em { color: #029e48; }
.ch-mail { background: #eef4ff; border-color: #dce8fb; color: #14233e; }
.ch-mail i { background: #0345c4; color: #fff; }
.ch-mail strong { font-size: 16.5px; }
.ch-mail strong, .ch-mail em { color: #0c3eb0; }
.ch-fax { background: #f2f4f7; border-color: #e5e9ee; color: #2b3a52; }
.ch-fax i { background: #5b6878; color: #fff; }
.ch-fax strong { color: #3a485c; }

/* ── 제품 상세 페이지 (/pages/products/<slug>) ── */
.pd-top {
  display: grid;
  grid-template-columns: minmax(280px, 460px) 1fr;
  gap: 34px;
  align-items: center;
}
.pd-img {
  display: grid;
  place-items: center;
  padding: 26px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
}
.pd-img img { max-width: 100%; max-height: 360px; object-fit: contain; }
.pd-cat {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 999px;
  background: #eef4ff;
  color: #0c3eb0;
  font-size: 12.5px;
  font-weight: 900;
}
.pd-head h2 { margin: 12px 0 6px; font-size: 32px; letter-spacing: -.5px; }
.pd-speed { margin: 0 0 14px; color: var(--muted); font-size: 15px; font-weight: 700; }
.pd-price { margin: 0 0 20px; color: #0c3eb0; font-size: 30px; font-weight: 900; letter-spacing: -.5px; }
.pd-price small { font-size: 15px; color: #74819a; font-weight: 800; margin-left: 4px; }
/* 2×2: 카카오톡 | 전화 / 견적받기 | 카탈로그 (운영자 지시) */
.pd-ctas { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; max-width: 560px; }
.pd-ctas a { justify-content: center; }
.pd-quote {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 15px 26px;
  border-radius: 14px;
  background: linear-gradient(135deg, #0a8a3a, #097c34);
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  box-shadow: 0 12px 26px rgba(10, 138, 58, .25);
}
.pd-quote:hover { transform: translateY(-2px); }
.pd-call {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 15px 22px;
  border-radius: 14px;
  border: 1.5px solid var(--line);
  background: #fff;
  color: #15233c;
  font-size: 15px;
  font-weight: 900;
}
.pd-call svg { width: 18px; height: 18px; color: #0a8a3a; }
.pd-call:hover { transform: translateY(-2px); border-color: #0a8a3a; }
.pd-catalog {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 15px 22px;
  border-radius: 14px;
  border: 1.5px solid #d4e2f7;
  background: #fff;
  color: #0c3eb0;
  font-size: 15px;
  font-weight: 900;
}
.pd-catalog svg { width: 18px; height: 18px; }
.pd-catalog:hover { transform: translateY(-2px); border-color: #0345c4; }
.pd-kakao {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 15px 22px;
  border-radius: 14px;
  background: #fee500;
  color: #191919;
  font-size: 15px;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(244, 217, 0, .35);
}
.pd-kakao svg { width: 19px; height: 19px; color: #3c1e1e; }
.pd-kakao:hover { transform: translateY(-2px); }
.pd-option-panel {
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(0, 1fr);
  gap: 22px;
  max-width: 100%;
  overflow: hidden;
  padding: 24px;
  border: 1px solid #dbe8f8;
  border-radius: 22px;
  background: linear-gradient(180deg, #fff, #f6fbff);
  box-shadow: 0 14px 34px rgba(35, 88, 148, .08);
}
.pd-option-head { display: grid; align-content: start; gap: 9px; }
.pd-option-eyebrow {
  color: #0a8a3a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
}
.pd-option-total {
  color: #0c3eb0;
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -.5px;
}
.pd-option-head p { margin: 0; color: #556376; font-size: 14px; font-weight: 700; line-height: 1.6; }
.pd-option-groups { display: grid; gap: 16px; }
.pd-option-field {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  border: 0;
}
.pd-option-field legend {
  padding: 0;
  color: #15233c;
  font-size: 14px;
  font-weight: 900;
}
.pd-option-choices {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 164px), 1fr));
  gap: 9px;
}
.pd-option-choices.two { grid-template-columns: repeat(auto-fit, minmax(min(100%, 210px), 1fr)); }
.pd-option-choices label {
  position: relative;
  min-height: 74px;
  cursor: pointer;
}
.pd-option-choices input { position: absolute; opacity: 0; }
.pd-option-choices span {
  display: grid;
  align-content: center;
  gap: 4px;
  height: 100%;
  padding: 13px 14px;
  border: 1.5px solid #dbe4f1;
  border-radius: 14px;
  background: #fff;
  color: #15233c;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.35;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.pd-option-choices small {
  display: block;
  color: #718097;
  font-size: 12px;
  font-weight: 800;
}
.pd-option-choices input:checked + span {
  border-color: #0345c4;
  background: #eef5ff;
  box-shadow: 0 0 0 3px rgba(3, 69, 196, .1);
}
.pd-option-quote {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  padding: 0 20px;
  border-radius: 14px;
  background: linear-gradient(135deg, #14b259, #078a38);
  color: #fff;
  font-size: 15px;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 12px 26px rgba(9, 150, 62, .26);
}
.pd-option-note { margin: -3px 0 0; color: #718097; font-size: 12px; font-weight: 700; line-height: 1.55; }
.pd-specs { margin: 0; padding: 4px 0 4px 20px; display: grid; gap: 9px; }
.pd-specs li { font-size: 14.5px; font-weight: 600; color: #2b3a52; }
.pd-pncons { grid-template-columns: 1fr 1fr; }
.pd-pros b, .pd-cons b { display: block; font-size: 15.5px; margin-bottom: 10px; }
.pd-pros ul, .pd-cons ul { margin: 0; padding-left: 20px; display: grid; gap: 8px; }
.pd-pros li, .pd-cons li { font-size: 13.5px; font-weight: 600; line-height: 1.55; }
.pd-pros { background: #f4fbf6; border-color: #ddf0e3; }
.pd-pros li { color: #14532d; }
.pd-cons { background: #fffaf0; border-color: #f5ead2; }
.pd-cons li { color: #6b5520; }
.pd-docs { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.pd-docs .pg-note { width: 100%; margin: 6px 0 0; }
.pg-link-btn.ghost { background: #fff; color: #0c3eb0; border: 1.5px solid #d9e5f8; }
/* 카드 하단 버튼 2종 — 자세히 보기(고스트) + 견적 문의하기(강조 그린) */
.catalog-links { display: grid; grid-template-columns: 1fr 1.35fr; gap: 9px; margin-top: 8px; }
.catalog-info .catalog-links a { margin-top: 0; min-height: 46px; border-radius: 11px; font-size: 14.5px; transition: transform .13s ease, box-shadow .13s ease, border-color .13s ease; }
.catalog-info a.catalog-detail-link {
  background: #fff;
  color: #0c3eb0;
  border: 1.5px solid #d4e2f7;
  box-shadow: none;
}
.catalog-info a.catalog-detail-link:hover { border-color: #0345c4; transform: translateY(-1px); }
.catalog-info .catalog-links a:not(.catalog-detail-link) {
  background: linear-gradient(135deg, #14b259, #078a38);
  box-shadow: 0 10px 22px rgba(9, 150, 62, .32);
}
.catalog-info .catalog-links a:not(.catalog-detail-link):hover { transform: translateY(-1px); box-shadow: 0 14px 26px rgba(9, 150, 62, .4); }
.info-table { display: grid; gap: 0; padding: 8px 24px; }
.info-table div {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid #eef2f8;
}
.info-table div:last-child { border-bottom: 0; }
.info-table dt { color: #74819a; font-size: 13px; font-weight: 800; }
.info-table dd { margin: 0; color: #15233c; font-size: 14px; font-weight: 700; }
.faq-cat {
  margin: 18px 0 4px;
  padding: 0 2px 8px;
  color: #0c3eb0;
  font-size: 14px;
  font-weight: 900;
  border-bottom: 1px solid #e7eefa;
}
.faq-cat:first-child { margin-top: 4px; }
.pg-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  height: 46px;
  padding: 0 20px;
  background: #03c75a;
  color: #fff;
  border-radius: 12px;
  font-size: 14.5px;
  font-weight: 900;
}
.pg-link-btn svg { width: 18px; height: 18px; }
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 12px; }
.cat-item {
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  transition: transform .14s ease, box-shadow .14s ease;
}
.cat-item:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(35, 88, 148, .12); }
.ci-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.ci-top b { font-size: 15.5px; letter-spacing: -.2px; }
.ci-top i { font-style: normal; color: #74819a; font-size: 11.5px; font-weight: 800; }
.cat-item p { margin: 0; color: var(--muted); font-size: 12.5px; font-weight: 600; }
.cat-item small { color: #8b96a6; font-size: 11.5px; font-weight: 600; }
.ci-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 6px; padding-top: 10px; border-top: 1px solid #eef2f8; }
.ci-price { color: #0c3eb0; font-size: 14.5px; font-weight: 900; }
.ci-price.ask { color: #74819a; }
.ci-foot a { color: var(--green); font-size: 12.5px; font-weight: 900; }
.faq details { border-bottom: 1px solid #eef2f8; padding: 4px 0; }
.faq details:last-child { border-bottom: 0; }
.faq summary { cursor: pointer; padding: 10px 0; font-size: 14.5px; font-weight: 800; color: #1b2a42; }
.faq p { margin: 2px 0 12px; color: #4a5870; font-size: 13.5px; font-weight: 500; line-height: 1.65; }
.pg-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px;
  padding: 22px 26px;
  background: var(--cta-blue);
  border-radius: 18px;
  color: #fff;
}
.pg-cta b { font-size: 19px; }
.pg-cta span { flex: 1; color: rgba(255,255,255,.85); font-size: 13.5px; font-weight: 600; min-width: 200px; }
.pg-cta a {
  height: 48px;
  display: inline-flex;
  align-items: center;
  padding: 0 22px;
  background: #fff;
  color: #0c4ac0;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 900;
  white-space: nowrap;
}
.quote-page .quote-wrap { max-width: 600px; margin: 0 auto; }
.quote-page .quote-card {
  width: 100%;
  margin-top: 0;
  grid-column: auto;
  justify-self: auto;
}

/* ───── 제품 상세 모달 ───── */
.p-modal { position: fixed; inset: 0; z-index: 120; }
.p-modal-bg { position: absolute; inset: 0; background: rgba(8, 15, 28, .55); }
.p-modal-card {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100% - 32px));
  max-height: 88vh;
  overflow-y: auto;
  padding: 26px 26px 20px;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 30px 80px rgba(8, 20, 45, .35);
}
.p-close {
  position: absolute;
  top: 14px;
  right: 14px;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 50%;
  background: #f1f4f9;
  color: #445062;
  cursor: pointer;
}
.p-close svg { width: 16px; height: 16px; }
.pm-top { display: grid; grid-template-columns: 150px 1fr; gap: 18px; align-items: center; }
.pm-img-wrap { display: grid; place-items: center; min-height: 150px; background: #f5f9ff; border-radius: 16px; padding: 10px; }
.pm-img { max-width: 128px; max-height: 138px; }
.pm-head { display: grid; gap: 7px; justify-items: start; }
.pm-head h3 { margin: 0; font-size: 22px; letter-spacing: -.3px; }
.pm-desc { margin: 0; color: var(--muted); font-size: 13.5px; font-weight: 700; }
.pm-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.pm-tags i {
  padding: 3px 8px;
  background: #eef4ff;
  border-radius: 7px;
  color: #2c4a7c;
  font-size: 11.5px;
  font-style: normal;
  font-weight: 800;
}
.pm-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 14px;
  margin: 18px 0 0;
  padding: 14px 16px;
  background: #f7faff;
  border: 1px solid #e3ecf9;
  border-radius: 14px;
}
.pm-info div { display: grid; gap: 1px; }
.pm-info dt { color: #74819a; font-size: 11.5px; font-weight: 800; }
.pm-info dd { margin: 0; color: #15233c; font-size: 14px; font-weight: 800; }
.pm-info .pm-rent { color: #0c3eb0; }
.pm-base,
.q-est-base {
  white-space: pre-line;
}
.print-color {
  display: inline-block;
  color: #0a8a30;
  font-weight: 900;
}
.pm-note { margin: 12px 0 0; color: #0a6b2e; font-size: 13px; font-weight: 700; }
.pm-ctas { display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 14px; }
.pm-page-link { display: inline-block; margin: 8px 0 2px; color: #0c3eb0; font-size: 13.5px; font-weight: 900; }
.pm-page-link:hover { text-decoration: underline; }
.pm-quote {
  height: 54px;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(180deg, #14a04a, #0a8a3a);
  color: #fff;
  font-size: 17px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(18, 147, 66, .22);
}
.pm-quote span { margin-left: 6px; }
.pm-call {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 54px;
  padding: 0 20px;
  border: 1.5px solid #bfe4cd;
  border-radius: 14px;
  color: #0a8a3a;
  font-size: 15px;
  font-weight: 900;
}
.pm-call svg { width: 18px; height: 18px; }
.pm-disc { margin: 12px 0 0; color: #93a0b2; font-size: 11px; font-weight: 600; }

/* ───── 플로팅 상담 CTA ───── */
.floating-cta {
  position: fixed;
  right: 22px;
  bottom: 26px;
  z-index: 80;
  display: grid;
  gap: 11px;
  justify-items: end;
}
.floating-cta a {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  box-shadow: 0 14px 32px rgba(10, 30, 60, .28);
}
.f-place { background: #03c75a; color: #fff; }
.f-place svg { width: 26px; height: 26px; }
.f-kakao { background: var(--kakao); }
.f-kakao img { width: 30px; height: 30px; border-radius: 8px; }
.f-call { background: linear-gradient(135deg, #14a04a, #0a8a3a); color: #fff; position: relative; }
.f-call svg { width: 24px; height: 24px; }
.f-call::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 999px;
  box-shadow: 0 0 0 0 rgba(20, 160, 74, .55);
  animation: f-pulse 2.2s ease-out infinite;
  pointer-events: none;
}
@keyframes f-pulse {
  0% { box-shadow: 0 0 0 0 rgba(20, 160, 74, .5); }
  70% { box-shadow: 0 0 0 14px rgba(20, 160, 74, 0); }
  100% { box-shadow: 0 0 0 0 rgba(20, 160, 74, 0); }
}

/* ───── advisor ───── */
.advisor-card {
  align-self: center;
  justify-self: start;
  margin-top: 30px;
  display: grid;
  justify-items: center;
  gap: 12px;
}
.advisor-card .bubble {
  position: relative;
  margin: 0;
  padding: 18px 22px;
  background: #fff;
  border-radius: 18px;
  text-align: center;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.55;
  box-shadow: var(--shadow);
}
.advisor-card .bubble::after {
  content: "";
  position: absolute;
  left: 34px;
  bottom: -8px;
  width: 16px;
  height: 16px;
  background: #fff;
  transform: rotate(45deg);
  border-radius: 3px;
}
.advisor-card img {
  width: 170px;
  justify-self: center;
  margin: 0;
}
.chart-card {
  justify-self: stretch;
  padding: 14px 16px 12px;
  background: rgba(255,255,255,.97);
  border-radius: 16px;
  box-shadow: var(--shadow);
}
.chart-card > b { display: block; margin-bottom: 8px; font-size: 13px; color: #243246; }
.chart {
  display: flex;
  align-items: end;
  justify-content: space-between;
  padding: 0 4px;
}
.chart span {
  display: grid;
  justify-items: center;
  gap: 6px;
  font-size: 10.5px;
  color: #56627a;
  font-weight: 700;
}
.chart span::before {
  content: "";
  width: 16px;
  height: var(--h);
  border-radius: 4px 4px 2px 2px;
  background: #17a84f;
}
.chart span.b::before { background: var(--blue); }
.chart span.lb::before { background: #63a5ff; }

/* ───── service strip ───── */
.service-strip {
  width: min(1180px, calc(100% - 40px));
  margin: -6px auto 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: rgba(255,255,255,.97);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow);
}
.service-strip article {
  display: grid;
  grid-template-columns: 48px 1fr;
  column-gap: 14px;
  align-items: center;
  align-content: center;
  min-height: 78px;
  padding: 14px 26px;
  border-right: 1px dashed #d7e0ee;
}
.service-strip article:last-child { border-right: 0; }
.s-ico {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
}
.s-ico svg { width: 32px; height: 32px; }
.s-truck { color: #1d6ae5; }
.s-check { color: #19a04c; }
.s-toner { color: #ffb70d; }
.s-head { color: #7a5af0; }
.s-visit { color: #19a04c; }
.service-strip b { font-size: 17px; }
.service-strip small { color: var(--muted); font-size: 13.5px; font-weight: 600; }

.home-trust {
  width: min(1180px, calc(100% - 40px));
  margin: 22px auto 0;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.35fr);
  gap: 18px;
  align-items: stretch;
  padding: 24px;
  border: 1px solid #dbe8f8;
  border-radius: 22px;
  background: linear-gradient(135deg, #f6fbff, #fff);
  box-shadow: 0 16px 34px rgba(35, 88, 148, .08);
}
.home-trust-copy { display: grid; align-content: center; gap: 8px; }
.home-trust-copy span {
  width: max-content;
  padding: 5px 11px;
  border-radius: 999px;
  background: #ecf3ff;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
}
.home-trust h2 {
  margin: 0;
  color: var(--ink);
  font-size: 24px;
  font-weight: 900;
  line-height: 1.32;
  letter-spacing: -.5px;
}
.home-trust p {
  margin: 0;
  color: #46566f;
  font-size: 14px;
  font-weight: 650;
  line-height: 1.7;
}
.home-trust-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.home-trust-points article {
  display: grid;
  align-content: start;
  gap: 7px;
  min-height: 126px;
  padding: 17px;
  border: 1px solid #e1ebf8;
  border-radius: 16px;
  background: #fff;
}
.home-trust-points b { color: #0c3eb0; font-size: 15px; font-weight: 900; line-height: 1.35; }
.home-trust-points small { color: #5d6c82; font-size: 12.5px; font-weight: 650; line-height: 1.55; }

/* ───── products ───── */
.products { width: min(1600px, calc(100% - 72px)); margin: 30px auto 0; }
.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}
.dot-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 17px;
  font-weight: 900;
}
.dot-label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--blue);
}
.fire-label { font-size: 19px; font-weight: 900; }
.see-all { color: var(--blue); font-size: 14px; font-weight: 800; }

.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(215px, 1fr));
  gap: 16px;
}
.product-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  padding: 16px 16px 12px;
  background: #fff;
  border: 1px solid #e4ecf7;
  border-radius: 16px;
  box-shadow: 0 10px 28px rgba(35, 88, 148, .08);
  overflow: hidden;
}
.product-card { position: relative; }
.product-card.is-best { border-color: #f5b73c; box-shadow: 0 10px 28px rgba(214, 144, 8, .16); }
.badge-best {
  position: absolute;
  top: -1px;
  right: 14px;
  padding: 5px 9px 6px;
  background: linear-gradient(180deg, #ff9d1c, #f27c00);
  color: #fff;
  border-radius: 0 0 9px 9px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: -.2px;
  box-shadow: 0 6px 14px rgba(242, 124, 0, .35);
}
.speed {
  display: block;
  justify-self: start;
  width: auto;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
  color: #6b7787;
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 700;
  overflow-wrap: anywhere;
}
.product-card.blue { background: #eef4ff; border-color: #dfeafc; }
.product-card.green { background: #effaf3; border-color: #dcf2e4; }
.product-card.orange { background: #fff7e8; border-color: #f8ecd2; }
.product-card.purple { background: #f4f1fe; border-color: #e8e2fa; }
.product-card.navy { background: #eef2fb; border-color: #dee6f5; }
.product-card.gray { background: #f2f4f7; border-color: #e5e9ee; }
.product-card h3 {
  margin: 13px 0 8px;
  font-size: 18px;
  letter-spacing: -.2px;
  white-space: nowrap;
}
.product-card .tag {
  justify-self: start;
  padding: 6px 11px;
  color: var(--blue);
  background: #fff;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 900;
  box-shadow: 0 2px 8px rgba(35, 88, 148, .1);
}
.product-card.blue .tag { color: #0235c1; }
.product-card.green .tag { color: #099030; }
.product-card.orange .tag { color: #f29200; }
.product-card.purple .tag { color: #5438de; }
.product-card.navy .tag { color: var(--navy); }
.product-card.gray .tag { color: #5b6878; }
.product-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 84px;
  gap: 14px;
  align-items: stretch;
}
.p-left {
  display: grid;
  grid-template-rows: 1fr auto auto auto;
  gap: 8px;
  justify-items: start;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.product-main .desc { margin: 0; color: var(--muted); font-size: 12px; font-weight: 600; white-space: nowrap; }
/* 카드용 표준화 정사각(420×420, official/card/) — 6카드 동일 크기·카드 내 안착 보장 */
.product-main img {
  align-self: center;
  justify-self: end;
  width: 84px;
  height: 108px;
  object-fit: contain;
  object-position: center;
  margin: -2px 0 0;
  filter: drop-shadow(0 16px 18px rgba(37, 61, 91, .14));
}
.product-main.has-desc { display: grid; position: relative; grid-template-columns: 1fr; }
.product-main.has-desc img {
  position: absolute;
  right: -8px;
  top: 18px;
  margin: 0;
  max-width: 134px;
}
.product-main.no-image {
  grid-template-columns: 1fr;
}
.product-main.no-image .p-left {
  grid-template-rows: auto auto auto auto;
}
.price strong {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  max-width: 100%;
  column-gap: 2px;
  row-gap: 10px;
  line-height: 1;
  white-space: normal;
}
.specs { display: flex; gap: 15px; }
.specs span {
  display: grid;
  justify-items: center;
  gap: 4px;
  color: #6b7787;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.specs svg { width: 19px; height: 19px; color: #8694a8; }
.price {
  justify-self: stretch;
  width: 100%;
  min-width: 0;
  margin-top: 4px;
}
.price .won-m { display: none; }
.price small { display: block; color: #56627a; font-size: 13px; font-weight: 700; margin-bottom: 2px; }
.price strong { color: #0235c1; font-size: 24px; font-weight: 900; letter-spacing: -.4px; }
.price .price-line {
  display: inline-flex;
  align-items: baseline;
  line-height: 1;
}
.price .suffix { color: #22304a; font-size: 13px; font-weight: 800; letter-spacing: 0; line-height: 1.2; }
.price .suffix.is-from {
  flex: 0 0 100%;
  display: block;
  margin-top: 3px;
  line-height: 1.45;
}
.product-card.is-d410s .price strong { row-gap: 5px; }
.product-card.is-d410s .price .suffix.is-from { margin-top: 0; line-height: 1.25; }
.green .price strong { color: #00793b; }
.orange .price strong { color: #ff9200; }
.purple .price strong { color: #5438de; }
.navy .price strong { color: var(--navy); }
.price.gap { min-height: 44px; }
.product-pager,
.catalog-pager {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}
.product-pager[hidden],
.catalog-pager[hidden] { display: none; }
.product-pager button,
.catalog-pager button {
  width: 38px;
  height: 38px;
  border: 1px solid #dce6f2;
  border-radius: 8px;
  background: #fff;
  color: #26354d;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}
.product-pager button.active,
.catalog-pager button.active {
  color: #fff;
  background: #0345c4;
  border-color: #0345c4;
  box-shadow: 0 10px 20px rgba(3, 69, 196, .18);
}
.catalog-pagination {
  display: grid;
  justify-items: center;
  gap: 12px;
  margin: 28px 0 14px;
  padding: 18px 16px;
  border-top: 2px solid #d7e4f5;
  border-bottom: 1px solid #e8eef7;
  background: linear-gradient(180deg, #f8fbff, #fff);
}
.catalog-pagination-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #17345f;
  font-size: 14px;
  font-weight: 900;
}
.catalog-pagination-label::before,
.catalog-pagination-label::after {
  content: "";
  width: 34px;
  height: 2px;
  background: #0345c4;
  border-radius: 999px;
  opacity: .62;
}
.catalog-pagination .catalog-pager {
  margin-top: 0;
}
.catalog-pagination .catalog-pager button {
  width: 46px;
  height: 46px;
  border: 2px solid #b8cbea;
  background: #fff;
  color: #17345f;
  font-size: 16px;
  box-shadow: 0 8px 18px rgba(23, 52, 95, .1);
}
.catalog-pagination .catalog-pager button.active {
  background: linear-gradient(180deg, #0757e5, #0239b2);
  border-color: #0239b2;
  box-shadow: 0 12px 24px rgba(3, 69, 196, .26);
}
.more {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.85);
  color: #0235c1;
  font-size: 14px;
  font-weight: 800;
}
.more i { font-style: normal; font-weight: 900; }
.green .more { color: #099030; }
.orange .more { color: #f58f00; }
.purple .more { color: #5438de; }
.navy .more { color: var(--navy); }
.gray .more { color: #0235c1; }

/* ───── 업종별 추천 ───── */
.industry { width: min(1600px, calc(100% - 72px)); margin: 34px auto 0; }
.industry-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}
.industry-grid a {
  display: grid;
  grid-template-columns: 46px 1fr;
  grid-template-rows: auto auto auto;
  column-gap: 12px;
  align-items: center;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 8px 22px rgba(35, 88, 148, .07);
  transition: transform .15s ease, box-shadow .15s ease;
}
.industry-grid a:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(35, 88, 148, .14);
}
.industry-grid i {
  grid-row: span 3;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  background: #f0f6ff;
  border-radius: 13px;
  font-style: normal;
  font-size: 23px;
}
.industry-grid b { font-size: 16.5px; letter-spacing: -.2px; word-break: keep-all; }
.industry-grid span { color: var(--muted); font-size: 12.5px; font-weight: 600; margin-top: 2px; word-break: keep-all; }
.industry-grid em {
  margin-top: 6px;
  font-style: normal;
  color: var(--blue);
  font-size: 12px;
  font-weight: 800;
  word-break: keep-all;
}

/* ───── CTA band ───── */
.cta-band {
  width: min(1600px, calc(100% - 72px));
  margin: 34px auto 32px;
}
.cta-desktop {
  min-height: 110px;
  display: grid;
  grid-template-columns: 132px minmax(max-content, 1fr) auto auto;
  align-items: center;
  gap: 30px;
  padding: 0 34px;
  color: #fff;
  background: var(--cta-blue);
  border-radius: 20px;
  box-shadow: 0 22px 50px rgba(1, 76, 179, .25);
}
/* 시안처럼 머리가 밴드 위로 둥글게 돌출 (PNG에 정수리 포함 — 평평하게 잘렸던 원인은 크롭 누락이었음) */
.cta-desktop img {
  height: 134px;
  align-self: end;
  margin: -30px 0 0;
}
.cta-copy h2 { margin: 0 0 6px; font-size: 26px; white-space: nowrap; }
.cta-copy p { margin: 0; color: rgba(255,255,255,.85); font-size: 15px; font-weight: 600; white-space: nowrap; }
.cta-desktop ol {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}
.cta-desktop li { display: flex; align-items: center; gap: 11px; }
.cta-desktop li:not(:last-child)::after {
  content: "";
  width: 34px;
  margin: 0 12px;
  border-top: 2px dotted rgba(255,255,255,.55);
}
.c-ico {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1.5px solid rgba(255,255,255,.7);
  border-radius: 50%;
}
.c-ico svg { width: 21px; height: 21px; color: #fff; }
.cta-desktop li:last-child .c-ico { background: #fff; border-color: #fff; }
.cta-desktop li:last-child .c-ico svg { color: var(--cta-blue); }
.c-txt { display: grid; font-size: 12.5px; font-weight: 700; color: rgba(255,255,255,.8); }
.c-txt em { font-style: normal; font-size: 14px; font-weight: 900; color: #fff; white-space: nowrap; }
.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: 56px;
  padding: 0 28px;
  color: #0c4ac0;
  background: #fff;
  border-radius: 12px;
  font-size: 17px;
  font-weight: 900;
  white-space: nowrap;
}
.cta-mobile { display: none; }

/* ───── hidden legacy sections (kept for reference) ───── */
.needs-grid, .detail-sections { display: none; }

.site-footer {
  margin-top: 12px;
  padding: 34px 0 38px;
  background: #f5f8fc;
  border-top: 1px solid var(--line);
}
.ft-inner { width: min(1400px, calc(100% - 72px)); margin: 0 auto; display: grid; gap: 18px; }
.ft-brand { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 14px; }
.ft-logo { height: 34px; width: auto; }
.ft-links { display: flex; flex-wrap: wrap; gap: 22px; font-size: 13.5px; font-weight: 800; color: #33415a; }
.ft-links a:hover { color: var(--blue); }
.ft-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 0 4px;
  border-top: 1px solid #e3eaf4;
}
.ft-info p { margin: 0; color: #67738a; font-size: 12.5px; line-height: 1.8; font-weight: 500; }
.ft-info b { color: #2b3a52; }
.ft-call { display: grid; justify-items: end; color: #00911f; font-size: 24px; font-weight: 900; line-height: 1.1; }
.ft-call small { color: #8b96a6; font-size: 11px; font-weight: 700; }
.ft-copy { color: #9aa5b5; font-size: 11px; font-weight: 600; }
.mobile-bottom { display: none; }

/* ───── ≤1560: CTA 스텝 숨김 ───── */
@media (max-width: 1560px) {
  .cta-desktop { grid-template-columns: 132px 1fr auto; }
  .cta-desktop ol { display: none; }
}

/* ───── ≤1280 ───── */
@media (max-width: 1280px) {
  .hero { grid-template-columns: 1fr 400px; padding-inline: 42px; }
  .advisor-card { display: none; }
  .quote-card { grid-column: 2; }
  .cta-desktop { grid-template-columns: 110px 1fr auto; }
}

/* ───── ≤1180: 데스크톱 네비 → 햄버거 ───── */
@media (max-width: 1400px) {
  .product-page .floating-cta { display: none; }
}

@media (max-width: 1180px) {
  .desktop-nav { display: none; }
  .menu-btn { display: inline-block; }
  .menu-btn svg { width: 26px; height: 26px; }
  .floating-cta { display: none; }
  .pd-option-panel { grid-template-columns: 1fr; }
  .pd-option-head { max-width: 620px; }
}

/* ───── ≤1024 (mobile / tablet) ───── */
@media (max-width: 1024px) {
  body { padding-bottom: 78px; background: #f6fbff; }
  .d-only { display: none; }
  .m-only { display: initial; }

  .site-header {
    height: 70px;
    padding: 0 8px;
    gap: 4px;
  }
  .header-actions { gap: 6px; }
  .brand { min-width: 0; flex-shrink: 0; }
  .brand-logo { height: 33px; }
  .brand-main { font-size: 12.5px; color: var(--logo-navy); white-space: nowrap; }
  .brand-main b {
    display: inline-block;
    padding: 1px 4px 2px;
    color: #fff;
    background: #0444b5;
    border-radius: 5px;
    font-size: 12px;
  }
  .brand-main .rental {
    color: #068021;
    border-left: 1.5px solid #c9d4e6;
    padding-left: 5px;
    margin-left: 1px;
  }
  .brand-sub { font-size: 9px; margin-top: 3px; }
  .desktop-nav { display: none; }
  .phone { gap: 3px; min-width: 0; margin-left: 0; }
  .phone-ico { width: 14px; height: 14px; color: #001e6d; flex-shrink: 0; }
  .phone span { white-space: nowrap; }
  .phone strong { color: #001e6d; font-size: 13.5px; letter-spacing: 0; }
  .phone small { font-size: 7.5px; margin-top: 2px; }
  .quick-btn {
    min-width: 0;
    height: 34px;
    padding: 0 7px;
    gap: 4px;
    font-size: 11.5px;
    background: #27894f;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .menu-btn { flex-shrink: 0; }
  .quick-btn svg { width: 13px; height: 13px; }
  .menu-btn { display: inline-block; padding: 0; }
  .menu-btn svg { width: 23px; height: 23px; }

  .hero {
    min-height: auto;
    display: block;
    padding: 0 17px;
  }
  .hero::after { display: none; }
  .hero-bg, .hero-photo { display: none; }
  .hero-copy {
    max-width: none;
    position: relative;
    margin: 0 -17px;
    padding: 18px 18px 24px;
    background:
      linear-gradient(90deg, #14253a 0%, rgba(20,37,58,.95) 22%, rgba(20,37,58,.55) 36%, rgba(20,37,58,0) 52%),
      url("./assets/generated/hero-mobile.png") right bottom / auto 100% no-repeat #14253a;
  }
  .hero-copy h1 {
    margin: 2px 0 8px;
    color: #fff;
    font-size: 20px;
    line-height: 1.28;
    letter-spacing: -.4px;
  }
  .hero-copy h1 em { color: #7db4ff; }
  .hero-copy p {
    margin-bottom: 12px;
    max-width: 190px;
    color: rgba(255,255,255,.88);
    font-size: 11px;
    font-weight: 500;
  }
  .hero-badges { flex-direction: column; gap: 7px; }
  .hero-badges span {
    grid-template-columns: 24px 1fr;
    gap: 8px;
    color: #fff;
    font-size: 11.5px;
    white-space: normal;
  }
  .hero-badges b { width: 24px; height: 24px; font-size: 12px; }
  .hero-badges b svg { width: 12px; height: 12px; }
  .hero-badges small { color: rgba(255,255,255,.72); font-size: 9px; }
  .hero-contact { display: none; }

  .quote-card {
    width: 100%;
    margin: 20px 0 0;
    position: relative;
    z-index: 2;
    padding: 24px 18px;
    border-radius: 24px;
  }
  .quote-title h2 { font-size: 23px; }
  .quote-title h2 b { color: inherit; font-size: inherit; }
  .quote-title li { font-size: 13px; }
  .step-ico { width: 50px; height: 50px; border-radius: 50%; }
  .quote-title li + li::before { top: 24px; }
  .quote-title li + li::after { top: 20px; }
  .quote-card fieldset {
    position: relative;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding-left: 96px;
  }
  .quote-card fieldset.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .quote-card fieldset.four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .quote-card legend {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
    font-size: 15px;
  }
  .quote-card label { height: 46px; }
  .quote-card label span { border-radius: 11px; }
  .q-opts label { height: 50px; }
  .q-opts.big label { height: 56px; }
  .q-extra label { height: 40px; }
  .q-extra fieldset { padding-left: 0; position: static; }
  .q-extra legend { position: static; transform: none; margin-bottom: 6px; }

  .service-strip {
    width: calc(100% - 34px);
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 16px;
    border-radius: 20px;
  }
  .service-strip article {
    display: block;
    min-height: 112px;
    padding: 16px 3px;
    text-align: center;
  }
  .s-ico { margin: 0 auto 8px; width: 40px; height: 40px; }
  .s-ico svg { width: 21px; height: 21px; }
  .service-strip b { display: block; font-size: 11.5px; letter-spacing: -.3px; word-break: keep-all; }
  .service-strip small { font-size: 8px; letter-spacing: -.2px; white-space: nowrap; }

  .home-trust {
    width: calc(100% - 34px);
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 14px;
    padding: 19px;
    border-radius: 18px;
  }
  .home-trust h2 { font-size: 21px; letter-spacing: -.4px; }
  .home-trust p { font-size: 13px; line-height: 1.65; }
  .home-trust-points { grid-template-columns: 1fr; gap: 8px; }
  .home-trust-points article {
    min-height: 0;
    padding: 14px 15px;
  }

  .products { width: calc(100% - 34px); margin-top: 30px; }
  .fire-label { display: inline-flex; }
  .see-all { display: inline-flex; }
  .product-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .product-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 33px 7px 14px;
    border-radius: 13px;
  }
  .product-card.is-best { padding-top: 12px; }
  .product-card .tag {
    order: -3;
    font-size: 10.5px;
    letter-spacing: -.3px;
    padding: 4px 9px;
    border-radius: 999px;
    white-space: nowrap;
  }
  .product-main, .p-left { display: contents; }
  .product-card h3 { order: -1; margin: 9px 0 0; font-size: 13px; letter-spacing: -.3px; white-space: nowrap; }
  .product-card .tag { box-shadow: 0 1px 4px rgba(35, 88, 148, .12); }
  .product-main img {
    order: -2;
    max-width: none;
    width: auto;
    height: 88px;
    margin: 9px 0 0;
  }
  .specs, .product-main .desc, .speed { display: none; }
  .badge-best {
    position: static;
    order: -4;
    margin: 0 auto 4px;
    padding: 3px 10px 4px;
    font-size: 10px;
    border-radius: 999px;
  }

  .industry { width: calc(100% - 34px); margin-top: 28px; }
  .industry-grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .industry-grid a { grid-template-columns: 34px 1fr; padding: 12px; border-radius: 13px; column-gap: 9px; }
  .industry-grid i { width: 34px; height: 34px; font-size: 17px; border-radius: 9px; }
  .industry-grid b { font-size: 12.5px; }
  .industry-grid span { font-size: 10px; }
  .industry-grid em { font-size: 10px; margin-top: 3px; }
  .price { margin-top: 4px; text-align: center; }
  .price small { display: none; }
  .price .won-m { display: inline; font-size: 9px; }
  .price strong {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 8px;
    font-size: 13.5px;
    line-height: 1;
    letter-spacing: -.3px;
    white-space: normal;
  }
  .price .price-line { line-height: 1; }
  .price .suffix { margin-left: 0; font-size: 8.5px; line-height: 1.45; }
  .price .suffix.is-from { flex-basis: 100%; margin-top: 0; }
  .more { display: none; }
  .price.gap { min-height: 0; }

  .cta-band { width: 100%; margin: 26px 0 0; }
  .cta-desktop { display: none; }
  .cta-mobile {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 92px;
    padding: 18px 22px;
    color: #fff;
    background: linear-gradient(180deg, #1d9450, #0f8a3c);
    border-radius: 24px 24px 0 0;
  }
  .cta-mobile svg { width: 30px; height: 30px; flex: 0 0 auto; }
  .cta-mobile span { flex: 1; display: grid; gap: 3px; }
  .cta-mobile strong { font-size: 20px; font-weight: 900; }
  .cta-mobile small { color: rgba(255,255,255,.88); font-size: 13px; font-weight: 600; }
  .cta-mobile i {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1.5px solid rgba(255,255,255,.7);
    border-radius: 50%;
    font-style: normal;
    font-weight: 900;
  }

  .p-modal-card {
    left: 0;
    top: auto;
    bottom: 0;
    transform: none;
    width: 100%;
    max-height: 86vh;
    border-radius: 22px 22px 0 0;
    padding: 22px 18px 18px;
  }
  .pm-top { grid-template-columns: 110px 1fr; gap: 12px; }
  .pm-img-wrap { min-height: 110px; }
  .pm-img { max-width: 92px; max-height: 100px; }
  .pm-head h3 { font-size: 18px; }
  .pm-ctas { grid-template-columns: 1fr; }
  .pm-call { justify-content: center; }

  .floating-cta { display: none; }

  .site-footer { padding: 22px 0 26px; }
  .ft-inner { width: calc(100% - 36px); gap: 13px; }
  .ft-logo { height: 26px; }
  .ft-links { gap: 13px; font-size: 12px; }
  .ft-info { padding-top: 13px; }
  .ft-info p { font-size: 11px; }
  .ft-call { font-size: 19px; }
  .page-head { padding: 22px 0 16px; }
  .page-head h1 { font-size: 22px; }
  .page-body { gap: 20px; padding-bottom: 44px; }
  .info-table { padding: 4px 18px; }
  .info-table div { grid-template-columns: 108px 1fr; }
  .pg-cta b { font-size: 16px; }
  .mobile-bottom {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 60;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    height: 74px;
    background: #fff;
    border-top: 1px solid var(--line);
    box-shadow: 0 -12px 30px rgba(25, 56, 102, .12);
  }
  .mobile-bottom a {
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 4px;
    color: #6e7888;
    font-size: 10.5px;
    font-weight: 800;
  }
  .mobile-bottom svg { width: 21px; height: 21px; }
  .mobile-bottom a.active { color: #0043c3; }

  /* 헤더 backdrop-filter가 fixed 자손의 containing block이 되어
     메뉴 오버레이가 헤더 박스에 갇힘 → 모바일에선 제거(배경 .96 불투명이라 차이 없음) */
  .site-header { backdrop-filter: none; }
  .site-header:has(.site-menu:not([hidden])) { z-index: 140; }
  .site-menu {
    position: fixed;
    inset: 0;
    top: 0;
    right: 0;
    z-index: 120;
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgba(10, 18, 32, .52);
  }
  .menu-card { width: 100%; max-width: 340px; padding: 10px; border-radius: 18px; }
  .site-menu a { padding: 13px 16px; font-size: 15.5px; }

  .cat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
  .cat-item { padding: 12px 13px; border-radius: 12px; }
  .ci-top b { font-size: 13.5px; }
  .ci-top i { font-size: 10.5px; }
  .cat-item p { font-size: 11.5px; }
  .cat-item small { font-size: 10px; }
  .ci-foot { margin-top: 4px; padding-top: 8px; }

  /* 제품 상세 페이지 */
  .pd-top { grid-template-columns: 1fr; gap: 18px; }
  .pd-img { padding: 18px; }
  .pd-img img { max-height: 240px; }
  .pd-head h2 { font-size: 25px; }
  .pd-price { font-size: 25px; }
  /* 모바일도 2×2 유지 — 폰트·패딩만 축소 */
  .pd-ctas { gap: 8px; }
  .pd-ctas a { width: 100%; justify-content: center; padding: 12px 8px; font-size: 13px; }
  .pd-quote { font-size: 13px; }
  .pd-option-panel { grid-template-columns: 1fr; padding: 18px; gap: 16px; border-radius: 18px; }
  .pd-option-total { font-size: 28px; }
  .pd-option-choices { grid-template-columns: 1fr; }
  .pd-option-choices.two { grid-template-columns: 1fr; }
  .pd-option-choices label { min-height: 62px; }
  .pd-option-choices span { padding: 12px 13px; }
  .pd-option-quote { min-height: 50px; padding-inline: 14px; }
  .pd-pncons { grid-template-columns: 1fr; }
}

/* ───── ≤374 (초소형: 견적 버튼 아이콘 전용) ───── */
@media (max-width: 374px) {
  .quick-btn .d-only, .quick-btn .m-only { display: none !important; }
  .quick-btn { padding: 0 10px; gap: 0; }
}

/* ───── ≤440 ───── */
@media (max-width: 440px) {
  .site-header { padding-inline: 10px; }
  .quote-card fieldset { padding-left: 84px; }
  .quote-card legend { font-size: 13px; }
  .quote-card label span { font-size: 14px; }
  .pd-option-panel { padding: 14px; border-radius: 16px; }
  .pd-option-head p { font-size: 13px; }
  .pd-option-field legend { font-size: 13px; }
  .pd-option-choices { gap: 8px; }
  .pd-option-choices label { min-height: 58px; }
  .pd-option-choices span { padding: 11px 12px; font-size: 13.5px; }
  .pd-option-choices small { font-size: 11.5px; }
  .pd-option-quote { font-size: 14px; }
}

/* 제품정보 카드 페이지 */
.product-page {
  background:
    radial-gradient(circle at 18% 0%, rgba(26, 119, 255, .09), transparent 34%),
    linear-gradient(180deg, #f6fbff 0, #fff 520px);
}
.catalog-main {
  width: min(1520px, calc(100% - 64px));
  margin: 0 auto;
  padding: 34px 0 58px;
}
.catalog-mobile-break { display: none; }
.catalog-hero {
  min-height: 360px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 430px;
  align-items: center;
  gap: 42px;
  padding: 48px 0 36px;
}
.catalog-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #0645c4;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
}
.catalog-kicker::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #12a04b;
}
.catalog-hero h1 {
  margin: 14px 0 16px;
  font-size: clamp(38px, 4vw, 62px);
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -1px;
}
.catalog-hero p {
  max-width: 720px;
  margin: 0;
  color: #435166;
  font-size: 19px;
  line-height: 1.7;
  font-weight: 700;
}
.catalog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.catalog-primary,
.catalog-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 8px;
  font-weight: 900;
}
.catalog-primary {
  color: #fff;
  background: linear-gradient(135deg, #064bd3, #0437a3);
  box-shadow: 0 14px 28px rgba(3, 69, 196, .2);
}
.catalog-secondary {
  color: #0a8a30;
  background: #fff;
  border: 1px solid #d7e6dd;
}
.catalog-hero-photo {
  min-height: 300px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(145deg, rgba(255,255,255,.95), rgba(237,247,255,.9)),
    radial-gradient(circle at 72% 20%, rgba(28, 156, 76, .12), transparent 34%);
  border: 1px solid #dfeaf7;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 22px 48px rgba(24, 76, 140, .14);
}
.catalog-hero-photo img {
  width: 92%;
  max-height: 315px;
  object-fit: contain;
  filter: drop-shadow(0 24px 28px rgba(29, 54, 88, .16));
}
.catalog-filter {
  position: sticky;
  top: 66px;
  z-index: 30;
  display: flex;
  gap: 8px;
  padding: 12px 0 18px;
  overflow-x: auto;
  background: linear-gradient(180deg, rgba(246,251,255,.98), rgba(246,251,255,.88));
  backdrop-filter: blur(12px);
}
.catalog-filter button {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 17px;
  color: #26354d;
  background: #fff;
  border: 1px solid #dce6f2;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}
.catalog-filter button.active {
  color: #fff;
  background: #0345c4;
  border-color: #0345c4;
  box-shadow: 0 10px 22px rgba(3, 69, 196, .18);
}
.catalog-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 4px 0 20px;
}
.catalog-summary article { padding: 0; }
.catalog-summary article > a {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 22px 24px;
  border-radius: inherit;
  transition: transform .13s ease, box-shadow .13s ease;
}
.catalog-summary article > a:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(34, 86, 148, .14); }
.catalog-summary article img {
  width: 132px;
  height: 132px;
  flex-shrink: 0;
  object-fit: contain;
}
.catalog-summary article div { min-width: 0; }
.catalog-summary article {
  background: #fff;
  border: 1px solid #e0eaf6;
  border-left: 5px solid #0345c4;
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(34, 86, 148, .08);
}
.catalog-summary article:nth-child(2) { border-left-color: #12a04b; }
.catalog-summary article:nth-child(3) { border-left-color: #ff9a1b; }
.catalog-summary span {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: #0c3eb0;
  font-size: 12px;
  font-weight: 900;
}
.catalog-summary b {
  display: block;
  margin-top: 9px;
  color: #10223e;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -.4px;
  word-break: keep-all;
}
.catalog-summary p {
  margin: 7px 0 0;
  color: #516075;
  font-size: 14px;
  font-weight: 700;
}
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.catalog-card {
  display: grid;
  grid-template-rows: 218px 1fr;
  min-height: 520px;
  background: #fff;
  border: 1px solid #e1eaf5;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 16px 36px rgba(28, 71, 126, .1);
}
.catalog-card[hidden] { display: none; }
.catalog-card.is-featured {
  border-color: rgba(3, 69, 196, .38);
  box-shadow: 0 20px 42px rgba(3, 69, 196, .14);
}
.catalog-image {
  position: relative;
  display: grid;
  place-items: center;
  padding: 18px;
  background:
    linear-gradient(180deg, #f7fbff, #eef6ff),
    radial-gradient(circle at 24% 10%, rgba(18, 160, 75, .12), transparent 30%);
  border-bottom: 1px solid #e4edf8;
}
.catalog-image img {
  width: 100%;
  height: 180px;
  object-fit: contain;
  filter: drop-shadow(0 18px 18px rgba(37, 61, 91, .16));
}
.catalog-image.no-image {
  align-content: center;
  gap: 12px;
  padding: 28px 18px 20px;
}
.catalog-image.no-image strong {
  max-width: 100%;
  color: #10223e;
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.05;
  text-align: center;
  overflow-wrap: anywhere;
}
.catalog-label {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  padding: 7px 10px;
  color: #fff;
  background: #0345c4;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 900;
}
.catalog-label.hot { background: #ff8c00; }
.catalog-label.value { background: #0a8a30; }
.catalog-label.speed { background: #6947d7; }
.catalog-label.premium { background: #14366e; }
.catalog-label.security { background: #566376; }
.catalog-info {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: 10px;
  padding: 22px;
}
.catalog-category {
  color: #0345c4;
  font-size: 13px;
  font-weight: 900;
}
.catalog-info h2 {
  margin: 0;
  color: #101b2b;
  font-size: 23px;
  line-height: 1.16;
  font-weight: 900;
  letter-spacing: -.3px;
}
.catalog-info p {
  margin: 0;
  color: #566276;
  font-size: 14px;
  line-height: 1.58;
  font-weight: 700;
}
.catalog-info dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 0;
}
.catalog-info dl div {
  min-height: 58px;
  padding: 10px 12px;
  background: #f7faff;
  border: 1px solid #e6eef8;
  border-radius: 8px;
}
.catalog-info dt { color: #7a8799; font-size: 11px; font-weight: 900; }
.catalog-info dd {
  margin: 5px 0 0;
  color: #14233c;
  font-size: 14px;
  line-height: 1.25;
  font-weight: 900;
}
.catalog-info a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: 8px;
  color: #fff;
  background: linear-gradient(135deg, #0b8d37, #04722b);
  border-radius: 8px;
  font-weight: 900;
  box-shadow: 0 12px 24px rgba(10, 138, 48, .18);
}
.catalog-guide {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 26px;
  margin-top: 36px;
  padding: 28px;
  color: #fff;
  background: linear-gradient(135deg, #092863, #0645c4 58%, #0a8a30);
  border-radius: 8px;
}
.catalog-guide span { color: rgba(255,255,255,.78); font-size: 13px; font-weight: 900; }
.catalog-guide h2 { margin: 8px 0 0; font-size: 28px; line-height: 1.25; }
.catalog-guide ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.catalog-guide li {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 8px;
}
.catalog-guide b { font-weight: 900; }
.catalog-guide li span { text-align: right; }
.catalog-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-top: 24px;
  padding: 26px 30px;
  background: #fff;
  border: 1px solid #e0eaf6;
  border-radius: 8px;
  box-shadow: 0 14px 30px rgba(34, 86, 148, .08);
}
.catalog-cta span { color: #0a8a30; font-size: 13px; font-weight: 900; }
.catalog-cta h2 { margin: 6px 0; font-size: 27px; letter-spacing: -.3px; }
.catalog-cta p { margin: 0; color: #5b6878; font-weight: 700; }
.catalog-cta a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  color: #fff;
  background: #0345c4;
  border-radius: 8px;
  font-weight: 900;
}

@media (min-width: 1025px) {
  .product-page .site-header {
    height: 58px;
    gap: 18px;
    padding: 0 28px;
  }
  .product-page .brand-logo { height: 42px; }
  .product-page .desktop-nav {
    gap: clamp(14px, 2.2vw, 40px);
    font-size: 14px;
  }
  .product-page .desktop-nav a {
    padding: 19px 0;
    border-bottom-width: 2px;
  }
  .product-page .header-actions { gap: 14px; }
  .product-page .phone { gap: 8px; }
  .product-page .phone-ico {
    width: 22px;
    height: 22px;
  }
  .product-page .phone strong { font-size: 23px; }
  .product-page .phone small {
    margin-top: 3px;
    font-size: 10px;
  }
  .product-page .quick-btn {
    min-width: 132px;
    height: 38px;
    padding: 0 18px;
    gap: 6px;
    font-size: 13px;
  }
  .product-page .quick-btn svg {
    width: 15px;
    height: 15px;
  }
  .product-page .catalog-main {
    width: min(1216px, calc(100% - 64px));
    padding: 24px 0 46px;
  }
  .product-page .catalog-hero {
    min-height: 288px;
    grid-template-columns: minmax(0, 1fr) 344px;
    gap: 34px;
    padding: 38px 0 28px;
  }
  .product-page .catalog-kicker {
    gap: 6px;
    font-size: 11px;
  }
  .product-page .catalog-kicker::before {
    width: 7px;
    height: 7px;
  }
  .product-page .catalog-hero h1 {
    margin: 11px 0 13px;
    font-size: clamp(30px, 3.2vw, 50px);
  }
  .product-page .catalog-hero p {
    max-width: 576px;
    font-size: 15px;
    line-height: 1.65;
  }
  .product-page .catalog-actions {
    gap: 10px;
    margin-top: 22px;
  }
  .product-page .catalog-primary,
  .product-page .catalog-secondary {
    min-height: 40px;
    padding: 0 18px;
    font-size: 13px;
  }
  .product-page .catalog-hero-photo { min-height: 240px; }
  .product-page .catalog-hero-photo img { max-height: 252px; }
  .product-page .catalog-filter {
    top: 58px;
    gap: 7px;
    padding: 10px 0 14px;
  }
  .product-page .catalog-filter button {
    min-height: 34px;
    padding: 0 14px;
    font-size: 12px;
  }
  .product-page .catalog-summary {
    gap: 11px;
    margin: 3px 0 16px;
  }
  .product-page .catalog-summary article > a {
    gap: 16px;
    min-height: 114px;
    padding: 16px 19px;
  }
  .product-page .catalog-summary article img {
    width: 166px;
    height: 132px;
  }
  .product-page .catalog-summary span {
    padding: 3px 9px;
    font-size: 10.5px;
  }
  .product-page .catalog-summary b {
    margin-top: 7px;
    font-size: 17px;
  }
  .product-page .catalog-summary p {
    margin-top: 5px;
    font-size: 12px;
    line-height: 1.45;
  }
  .product-page .catalog-grid { gap: 14px; }
  .product-page .catalog-card {
    grid-template-rows: 212px 1fr;
    min-height: 454px;
  }
  .product-page .catalog-image { padding: 14px; }
  .product-page .catalog-image img {
    width: auto;
    max-width: 86%;
    height: 180px;
    transform: scale(1.12);
    transform-origin: center;
  }
  .product-page .catalog-label {
    top: 11px;
    left: 11px;
    padding: 5px 9px;
    font-size: 10px;
  }
  .product-page .catalog-info {
    gap: 8px;
    padding: 18px;
  }
  .product-page .catalog-category { font-size: 11px; }
  .product-page .catalog-info h2 { font-size: 18.5px; }
  .product-page .catalog-info p {
    font-size: 12px;
    line-height: 1.5;
  }
  .product-page .catalog-info dl {
    gap: 7px;
    margin-top: 6px;
  }
  .product-page .catalog-info dl div {
    min-height: 46px;
    padding: 8px 10px;
  }
  .product-page .catalog-info dt { font-size: 9.5px; }
  .product-page .catalog-info dd {
    margin-top: 4px;
    font-size: 12px;
  }
  .product-page .catalog-info .catalog-links a {
    min-height: 40px;
    font-size: 12.5px;
    border-radius: 8px;
  }
  .product-page .catalog-pagination {
    margin: 22px 0 12px;
    padding: 15px 14px;
  }
  .product-page .catalog-pagination .catalog-pager button {
    width: 40px;
    height: 40px;
    font-size: 14px;
  }
  .product-page .catalog-guide {
    grid-template-columns: 256px 1fr;
    gap: 20px;
    margin-top: 28px;
    padding: 22px;
  }
  .product-page .catalog-guide h2 { font-size: 22px; }
  .product-page .catalog-guide li { padding: 11px 13px; }
  .product-page .catalog-cta {
    gap: 20px;
    margin-top: 20px;
    padding: 22px 24px;
  }
  .product-page .catalog-cta h2 { font-size: 22px; }
  .product-page .catalog-cta a {
    min-height: 42px;
    padding: 0 20px;
    font-size: 13px;
  }
}

@media (max-width: 1180px) {
  .catalog-hero { grid-template-columns: 1fr; }
  .catalog-hero-photo { display: none; }
  .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalog-summary { grid-template-columns: 1fr; }
  .catalog-guide { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  html, body { overflow-x: hidden; }
  .map-copy { padding: 18px 18px 0; }
  .naver-map-canvas { min-height: 300px; }
  .map-actions {
    display: grid;
    grid-template-columns: 1fr;
    padding: 0 18px 18px;
  }
  .map-actions .pg-link-btn {
    width: 100%;
    justify-content: center;
  }
  .catalog-main {
    width: calc(100% - 28px);
    padding-top: 22px;
    padding-bottom: 92px;
  }
  .catalog-hero { min-height: 0; padding: 24px 0 18px; }
  .catalog-hero h1 {
    max-width: 100%;
    font-size: 32px;
    letter-spacing: -.7px;
    word-break: keep-all;
    overflow-wrap: normal;
  }
  .catalog-hero p { font-size: 15px; }
  .catalog-mobile-break { display: block; }
  .catalog-actions { display: grid; grid-template-columns: 1fr; }
  .catalog-filter {
    top: 62px;
    margin-inline: -14px;
    padding-inline: 14px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    overflow: visible;
  }
  .catalog-filter button {
    width: 100%;
    min-height: 38px;
    padding: 0 8px;
    font-size: 12px;
  }
  .catalog-summary { grid-template-columns: 1fr; gap: 10px; }
  .catalog-summary article > a { padding: 13px 15px; gap: 13px; }
  .catalog-summary article img { width: 82px; height: 82px; }
  .catalog-summary b { font-size: 17px; }
  /* 모바일 카탈로그 = 가로 2열 (운영자 지시) */
  .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
  .catalog-card {
    grid-template-rows: 120px 1fr;
    min-height: auto;
  }
  .catalog-image img { height: 100px; }
  .catalog-label { font-size: 10px; padding: 4px 8px; }
  .catalog-info { padding: 12px; gap: 7px; }
  .catalog-category { font-size: 10.5px; }
  .catalog-info h2 { font-size: 15px; letter-spacing: -.4px; word-break: keep-all; }
  .catalog-info p { font-size: 11px; line-height: 1.45; }
  .catalog-info dl { grid-template-columns: 1fr; gap: 6px; }
  .catalog-info dl div { min-height: 0; padding: 7px 10px; }
  .catalog-info dt { font-size: 10px; }
  .catalog-info dd { font-size: 12px; margin-top: 3px; }
  .catalog-links { grid-template-columns: 1fr; gap: 7px; }
  .catalog-info .catalog-links a { min-height: 38px; font-size: 12.5px; border-radius: 9px; }
  .catalog-guide { padding: 22px; }
  .catalog-guide li { display: grid; }
  .catalog-guide li span { text-align: left; }
  .catalog-cta { display: grid; padding: 22px; }
  .catalog-cta h2 { font-size: 23px; }
  .catalog-cta a { width: 100%; }
}

/* ── 회사소개 브랜드 스토리 (2026-06-12, 운영자 제공 원문 디자인) ── */
.story-card { padding: 30px 32px 26px; }
.story-since { display: inline-block; font-size: 11.5px; font-weight: 900; letter-spacing: .16em; color: var(--blue); background: #ecf3ff; border: 1px solid #cdddfb; border-radius: 999px; padding: 6px 13px; }
.story-card h2.story-h { margin: 14px 0 10px; font-size: 25px; font-weight: 900; letter-spacing: -.5px; line-height: 1.32; color: var(--ink); }
.story-p { margin: 0; font-size: 15.5px; line-height: 1.8; color: #243246; font-weight: 500; max-width: 660px; }
.story-p b { color: #0c3eb0; }
.story-quote { margin: 20px 0 0; padding: 22px 26px; border-radius: 14px; background: linear-gradient(135deg, #0b2a63, var(--blue)); color: #fff; }
.story-quote p { margin: 0; font-size: 20px; font-weight: 800; letter-spacing: -.3px; line-height: 1.45; }
.story-quote p b { color: var(--yellow); }
.story-quote cite { display: block; margin-top: 9px; font-style: normal; font-size: 12.5px; font-weight: 600; color: #b9cdf5; }
.story-values { list-style: none; display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 18px 0 0; padding: 0; }
.story-values li { display: grid; gap: 5px; justify-items: start; background: #f6f9ff; border: 1px solid #e2ecfb; border-radius: 13px; padding: 16px 16px 14px; }
.story-values svg { width: 25px; height: 25px; color: var(--blue); }
.story-values b { font-size: 15px; color: var(--ink); letter-spacing: -.2px; }
.story-values li > span { font-size: 12.5px; font-weight: 600; color: var(--muted); line-height: 1.5; }
.story-close { margin: 16px 2px 0; font-size: 15px; font-weight: 800; color: var(--ink); line-height: 1.65; }
.story-sign { margin: 18px 2px 0; text-align: right; font-size: 13px; font-weight: 600; color: var(--muted); }
.story-sign b { font-size: 17px; font-weight: 900; color: var(--ink); margin-left: 7px; letter-spacing: 2px; }
.trust-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.trust-proof article {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 204px;
  padding: 22px;
  border: 1px solid #dfeaf8;
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: 0 8px 22px rgba(35, 88, 148, .05);
}
.trust-proof span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: #ecf3ff;
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
}
.trust-proof b { color: var(--ink); font-size: 17px; font-weight: 900; line-height: 1.4; }
.trust-proof p { margin: 0; color: #4a5870; font-size: 13.5px; font-weight: 650; line-height: 1.7; }

/* ── 견적 폼 개인정보 수집·이용 동의 (2026-06-12) ──
   주의: .quote-card label/span 일반 규칙(알약 옵션버튼 + checked 파란 그라데이션)이
   동의 라벨에도 매칭되므로 아래는 전부 그보다 특이도 높은 오버라이드로 무력화한다. */
.q-consent { margin: 14px 0 0; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.quote-card label.q-agree-row { display: flex; align-items: center; gap: 8px; height: auto; cursor: pointer; font-size: 14px; font-weight: 700; color: #243246; }
.quote-card label.q-agree-row input.q-agree { position: static; opacity: 1; width: 18px; height: 18px; accent-color: var(--blue); cursor: pointer; flex-shrink: 0; margin: 0; }
.quote-card label.q-agree-row span,
.quote-card label.q-agree-row input:checked + span { display: inline; height: auto; place-items: unset; background: none; border: 0; border-radius: 0; box-shadow: none; color: #243246; font-weight: 700; }
.q-agree-row em { font-style: normal; color: #d1342f; font-size: 12px; font-weight: 800; }
.q-privacy { font-size: 12.5px; }
.q-privacy summary { color: var(--muted); text-decoration: underline; text-underline-offset: 3px; cursor: pointer; font-weight: 600; list-style: none; }
.q-privacy summary::-webkit-details-marker { display: none; }
.q-privacy[open] { flex-basis: 100%; order: 9; }
.q-privacy-body { margin-top: 8px; background: #f6f8fc; border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; display: grid; gap: 5px; }
.q-privacy-body p { margin: 0; color: #4a5870; font-size: 12.5px; line-height: 1.6; font-weight: 500; }
.q-privacy-body b { color: #16243b; margin-right: 7px; }
@media (max-width: 720px) {
  .q-consent { gap: 10px; }
  .q-agree-row { font-size: 13.5px; }
}
.q-privacy-link a { color: var(--blue); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }

/* ── 개인정보처리방침 문서 + 푸터 법적 표기 (2026-06-12) ── */
.privacy-doc h3 { margin: 22px 0 8px; font-size: 16px; color: var(--ink); letter-spacing: -.2px; }
.privacy-doc ul { margin: 0; padding-left: 19px; display: grid; gap: 5px; }
.privacy-doc li { color: #3d4b61; font-size: 14px; line-height: 1.7; font-weight: 500; }
.privacy-doc li b { color: #16243b; }
.ft-legal { margin: 6px 0 0; font-size: 11.5px; color: #93a0b4; font-weight: 600; }
@media (max-width: 720px) {
  .story-card { padding: 24px 20px 22px; }
  .story-card h2.story-h { font-size: 21px; }
  .story-quote { padding: 18px 20px; }
  .story-quote p { font-size: 17px; }
  .story-values { grid-template-columns: 1fr; }
  .compare-points { grid-template-columns: 1fr; }
  .trust-proof { grid-template-columns: 1fr; }
  .trust-proof article { min-height: 0; padding: 18px; }
}
