/* ════════════════════════════════════════════════════════════
   도움이사 (도움24) — Cloudflare 사이트 공유 스타일
   디자인: 시원한 쿨 톤 캔버스 + 딥 네이비 섹션 + 스카이블루/틸 포인트
           + 에디토리얼 타이포(모노 eyebrow).
   모든 규칙은 .d24 스코프.
   ════════════════════════════════════════════════════════════ */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");

.d24{
  /* 포인트 — 시원한 스카이블루 + 틸 */
  --c-primary:#0E97D9; --c-primary-strong:#0A77B0; --c-primary-weak:#D7EFFB; --c-primary-soft:#ECF7FC;
  --c-accent:#15B8A6; --c-accent-strong:#0E9387; --c-accent-weak:#D6F1ED;
  /* 잉크 / 텍스트 (쿨 네이비 슬레이트) */
  --c-ink:#0D2235; --c-ink-2:#143246; --c-text:#1B2C3A; --c-text-sub:#56697A; --c-text-faint:#92A4B2;
  /* 페이퍼 / 면 (쿨 화이트) */
  --paper:#EDF3F8; --c-bg:#FAFCFE; --c-bg-soft:#E1ECF3; --c-bg-sunken:#D5E3EC;
  --c-line:#DAE6EE; --c-line-strong:#C1D2DE;
  /* 카드 타일용 뮤트 톤 (저채도 쿨) */
  --c-sky:#DDEAF4; --c-mint:#D8EEE9; --c-peach:#E3EEF3; --c-lilac:#E0E9F2; --c-rose:#D9EAF1;
  /* 상태 */
  --c-success:#12977E; --c-warn:#C98A24; --c-danger:#D24B4C; --c-star:#E0A52E;
  /* 형태 */
  --r-sm:10px; --r:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
  --sh-xs:0 1px 2px rgba(12,40,64,.06); --sh-sm:0 8px 22px rgba(12,40,64,.09);
  --sh:0 16px 40px rgba(12,40,64,.13); --sh-lg:0 30px 70px rgba(8,30,50,.24);
  --sh-brand:0 12px 26px rgba(14,151,217,.30);
  --ease:cubic-bezier(.2,.7,.2,1); /* @kind other */
  --font:"Pretendard","Apple SD Gothic Neo",system-ui,"Noto Sans KR",sans-serif;
  --mono:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace; /* @kind font */
  --container:1180px; --header-h:68px;
  font-family:var(--font); color:var(--c-text); line-height:1.62; -webkit-font-smoothing:antialiased; text-align:left; word-break:keep-all;
  background:var(--paper);
}
.d24 *{ box-sizing:border-box; }
.d24 h1,.d24 h2,.d24 h3,.d24 h4{ margin:0; line-height:1.12; letter-spacing:-.03em; color:var(--c-ink); }
.d24 p{ margin:0; }
.d24 a{ color:inherit; text-decoration:none; cursor:pointer; }
.d24 img{ max-width:100%; display:block; }
.d24 button{ font-family:inherit; cursor:pointer; border:none; background:none; }
.d24 .wrap{ max-width:var(--container); margin:0 auto; padding:0 22px; }
.d24 .wrap-narrow{ max-width:760px; margin:0 auto; padding:0 22px; }
.d24 section{ padding:clamp(48px,7vw,92px) 0; }
.d24 .center{ text-align:center; }

/* eyebrow — 모노 + 대시 (에디토리얼 시그니처) */
.d24 .eyebrow{ display:inline-block; font-family:var(--mono); color:var(--c-text-sub); font-weight:600; font-size:12px; letter-spacing:.18em; text-transform:uppercase; margin-bottom:16px; }
.d24 .eyebrow::before{ content:"— "; color:var(--c-primary); }
.d24 .sec-head{ max-width:680px; margin:0 auto 48px; text-align:center; }
.d24 .sec-head h2{ font-size:clamp(26px,4.2vw,42px); font-weight:800; }
.d24 .sec-head p{ color:var(--c-text-sub); font-size:clamp(15px,2vw,18px); margin-top:14px; }

/* 버튼 */
.d24 .btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; font-weight:700; border-radius:var(--r-pill); white-space:nowrap; min-height:52px; padding:0 28px; font-size:15.5px; letter-spacing:-.01em; transition:transform .18s var(--ease),background .2s,box-shadow .2s,border-color .2s,color .2s; }
.d24 .btn-lg{ min-height:60px; padding:0 36px; font-size:17px; }
.d24 .btn-sm{ min-height:44px; padding:0 20px; font-size:14px; }
.d24 .btn-block{ width:100%; }
.d24 .btn-primary{ background:var(--c-primary); color:#fff; box-shadow:var(--sh-brand); }
.d24 .btn-primary:hover{ background:var(--c-primary-strong); transform:translateY(-2px); }
.d24 .btn-primary:active{ transform:scale(.985); }
.d24 .btn-ink{ background:var(--c-ink); color:#fff; }
.d24 .btn-ink:hover{ background:var(--c-ink-2); transform:translateY(-2px); }
.d24 .btn-soft{ background:var(--c-bg-soft); color:var(--c-ink); }
.d24 .btn-soft:hover{ background:var(--c-bg-sunken); }
.d24 .btn-white{ background:#fff; color:var(--c-ink); box-shadow:var(--sh-sm); }
.d24 .btn-white:hover{ transform:translateY(-2px); box-shadow:var(--sh); }
.d24 .btn-ghost{ background:transparent; color:var(--c-ink); border:1.5px solid var(--c-line-strong); }
.d24 .btn-ghost:hover{ border-color:var(--c-ink); background:var(--c-ink); color:#fff; }
.d24 .btn[disabled]{ opacity:.45; pointer-events:none; }

/* 헤더 */
.d24 .hdr{ position:sticky; top:0; z-index:50; background:rgba(237,243,248,.82); backdrop-filter:saturate(140%) blur(14px); -webkit-backdrop-filter:saturate(140%) blur(14px); border-bottom:1px solid transparent; transition:.25s; }
.d24 .hdr.scrolled{ background:rgba(244,248,251,.96); border-color:var(--c-line); }
.d24 .hdr .bar{ height:var(--header-h); display:flex; align-items:center; gap:16px; }
.d24 .hdr .logo{ display:inline-flex; align-items:center; gap:10px; }
.d24 .hdr .logo svg{ width:32px; height:32px; }
.d24 .hdr .logo b{ font-weight:800; font-size:20px; letter-spacing:-.03em; color:var(--c-ink); }
.d24 .hdr nav.main{ display:none; gap:2px; margin:0 auto; }
.d24 .hdr nav.main a{ font-weight:600; color:var(--c-text-sub); padding:10px 15px; border-radius:var(--r-pill); font-size:15px; transition:.15s; }
.d24 .hdr nav.main a:hover{ color:var(--c-ink); }
.d24 .hdr nav.main a.on{ color:var(--c-ink); }
.d24 .hdr .right{ display:none; align-items:center; gap:16px; }
.d24 .hdr .right .tel{ font-weight:800; color:var(--c-ink); font-size:15px; font-variant-numeric:tabular-nums; }
.d24 .hdr .right .tel small{ font-family:var(--mono); color:var(--c-text-faint); font-weight:500; font-size:11px; letter-spacing:.06em; margin-right:6px; }
.d24 .hdr .burger{ display:flex; flex-direction:column; gap:5px; padding:8px; margin-left:auto; }
.d24 .hdr .burger span{ width:22px; height:2px; background:var(--c-ink); border-radius:2px; transition:.2s; }
@media(min-width:1000px){ .d24 .hdr nav.main{ display:flex; } .d24 .hdr .right{ display:flex; } .d24 .hdr .burger{ display:none; } }

/* 모바일 드로어 */
.d24 .drawer{ position:fixed; inset:0; z-index:100; display:none; }
.d24 .drawer.open{ display:block; }
.d24 .drawer .dim{ position:absolute; inset:0; background:rgba(22,19,14,.5); opacity:0; transition:opacity .25s; }
.d24 .drawer.open .dim{ opacity:1; }
.d24 .drawer .panel{ position:absolute; top:0; right:0; height:100%; width:min(360px,86vw); background:var(--c-bg); box-shadow:var(--sh-lg); transform:translateX(100%); transition:transform .3s var(--ease); padding:22px; overflow-y:auto; }
.d24 .drawer.open .panel{ transform:none; }
.d24 .drawer .phead{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.d24 .drawer .phead .tel{ font-weight:800; color:var(--c-ink); font-variant-numeric:tabular-nums; }
.d24 .drawer .x{ font-size:22px; color:var(--c-text-sub); width:38px; height:38px; border-radius:50%; }
.d24 .drawer nav{ display:flex; flex-direction:column; gap:2px; }
.d24 .drawer nav a{ padding:16px 6px; font-weight:700; color:var(--c-ink); font-size:18px; letter-spacing:-.02em; border-bottom:1px solid var(--c-line); }
.d24 .drawer nav a.on{ color:var(--c-primary); }
.d24 .drawer .dcta{ margin-top:20px; }

/* 페이지 히어로 (서브페이지) */
.d24 .phero{ background:var(--paper); border-bottom:1px solid var(--c-line); }
.d24 .phero .in{ padding-top:clamp(40px,5.5vw,76px); padding-bottom:clamp(28px,4vw,44px); }
.d24 .phero .crumb{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--c-text-faint); margin-bottom:18px; }
.d24 .phero .crumb a:hover{ color:var(--c-ink); }
.d24 .phero h1{ font-size:clamp(30px,5vw,56px); font-weight:800; }
.d24 .phero p{ color:var(--c-text-sub); font-size:clamp(15px,2vw,19px); margin-top:14px; max-width:60ch; }

/* 홈 히어로 — 잉크 다크 (시그니처) */
.d24 .hero{ padding-top:clamp(16px,2.4vw,26px); }
.d24 .hero .banner{ position:relative; overflow:hidden; border-radius:var(--r-xl); background:var(--c-ink); color:#fff; padding:clamp(32px,5.5vw,68px); display:flex; align-items:center; gap:28px; }
.d24 .hero .banner::after{ content:""; position:absolute; right:-12%; top:-30%; width:55%; height:160%; background:radial-gradient(closest-side,rgba(14,151,217,.36),transparent 70%); pointer-events:none; }
.d24 .hero .copy{ position:relative; z-index:2; flex:1; }
.d24 .hero .eyebrow{ color:rgba(255,255,255,.62); }
.d24 .hero .eyebrow::before{ color:var(--c-accent); }
.d24 .hero h1{ color:#fff; font-size:clamp(30px,5.2vw,58px); font-weight:800; margin:4px 0 18px; }
.d24 .hero h1 b{ color:#7DD3FC; font-weight:800; }
.d24 .hero .sub{ color:rgba(255,255,255,.74); font-size:clamp(15px,2vw,19px); margin-bottom:26px; }
.d24 .hero .hbtns{ display:flex; flex-wrap:wrap; gap:10px; }
.d24 .hero .mascot{ position:relative; z-index:2; width:clamp(120px,21vw,230px); aspect-ratio:1; flex:0 0 auto; display:none; }
.d24 .hero .mascot .blob{ width:100%; height:100%; border-radius:46% 54% 52% 48%/52% 46% 54% 48%; background:linear-gradient(160deg,rgba(157,176,255,.22),rgba(31,184,148,.18)); border:1px solid rgba(255,255,255,.14); display:flex; align-items:center; justify-content:center; font-size:clamp(54px,9vw,104px); }
.d24 .hero .mascot .tag{ position:absolute; bottom:4px; left:50%; transform:translateX(-50%); font-family:var(--mono); font-size:10px; letter-spacing:.04em; color:rgba(255,255,255,.5); white-space:nowrap; }
@media(min-width:760px){ .d24 .hero .mascot{ display:block; } }

/* 신뢰 스트립 (정직한 강점 스크롤) */
.d24 .ticker{ margin-top:14px; display:flex; align-items:center; gap:14px; background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-pill); padding:9px 9px 9px 18px; overflow:hidden; }
.d24 .ticker .live{ flex:0 0 auto; display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-weight:600; font-size:11px; letter-spacing:.1em; color:var(--c-ink); text-transform:uppercase; }
.d24 .ticker .live .dot{ width:7px; height:7px; border-radius:50%; background:var(--c-accent); animation:d24pulse 1.6s infinite; }
@keyframes d24pulse{ 0%{box-shadow:0 0 0 0 rgba(31,184,148,.5)} 70%{box-shadow:0 0 0 7px rgba(31,184,148,0)} 100%{box-shadow:0 0 0 0 rgba(31,184,148,0)} }
.d24 .ticker .vp{ flex:1; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.d24 .ticker .track{ display:inline-flex; gap:28px; white-space:nowrap; animation:d24scroll 36s linear infinite; }
.d24 .ticker .it{ font-size:13px; color:var(--c-text-sub); display:inline-flex; align-items:center; gap:7px; }
.d24 .ticker .it b{ font-weight:700; color:var(--c-ink); }
.d24 .ticker .it .ck{ color:var(--c-accent-strong); font-weight:800; }
@keyframes d24scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
.d24 .ticker:hover .track{ animation-play-state:paused; }

/* 그리드 */
.d24 .g2{ display:grid; gap:18px; grid-template-columns:1fr; } @media(min-width:760px){ .d24 .g2{ grid-template-columns:1fr 1fr; } }
.d24 .g3{ display:grid; gap:18px; grid-template-columns:1fr; } @media(min-width:680px){ .d24 .g3{ grid-template-columns:repeat(3,1fr); } }
.d24 .g4{ display:grid; gap:16px; grid-template-columns:1fr 1fr; } @media(min-width:980px){ .d24 .g4{ grid-template-columns:repeat(4,1fr); } }

/* 서비스 아이콘 타일 — 개수와 무관하게 가운데 정렬 */
.d24 .svcg{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px; }
.d24 .svct{ flex:1 1 150px; max-width:212px; display:flex; flex-direction:column; align-items:center; gap:14px; padding:26px 14px; border:1px solid var(--c-line); border-radius:var(--r-lg); background:var(--c-bg); transition:background .2s,transform .2s,box-shadow .2s,border-color .2s; text-align:center; }
.d24 .svct:hover{ transform:translateY(-4px); box-shadow:var(--sh-sm); border-color:var(--c-line-strong); }
.d24 .svct .ic{ width:68px; height:68px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:32px; border:1px solid var(--c-line); transition:.2s; }
.d24 .svct:hover .ic{ border-color:var(--c-ink); }
.d24 .svct .nm{ font-size:14.5px; font-weight:800; color:var(--c-ink); }

/* 서비스 상세 카드 */
.d24 .svc-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:18px; }
.d24 .svc-grid>.svcard{ flex:1 1 320px; max-width:384px; }
.d24 .svcard{ background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-lg); padding:28px; transition:transform .2s,box-shadow .2s,border-color .2s; }
.d24 .svcard:hover{ transform:translateY(-4px); box-shadow:var(--sh); border-color:var(--c-line-strong); }
.d24 .svcard .ic{ width:58px; height:58px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:28px; margin-bottom:18px; border:1px solid var(--c-line); }
.d24 .svcard h3{ font-size:21px; font-weight:800; margin-bottom:8px; }
.d24 .svcard .lead{ color:var(--c-text-sub); font-size:14px; margin-bottom:16px; }
.d24 .svcard .feat{ display:flex; flex-direction:column; gap:8px; margin-bottom:20px; padding-top:16px; border-top:1px solid var(--c-line); }
.d24 .svcard .feat span{ font-size:14px; color:var(--c-text); display:flex; gap:8px; align-items:flex-start; }
.d24 .svcard .feat span:before{ content:"→"; color:var(--c-primary); font-weight:700; }
.d24 .svcard .price{ font-weight:800; color:var(--c-ink); font-size:14px; }
.d24 .svcard .price b{ font-size:22px; color:var(--c-ink); font-variant-numeric:tabular-nums; } .d24 .svcard .price small{ color:var(--c-text-sub); font-weight:700; }

/* 강점 */
.d24 .why{ padding:26px; border-radius:var(--r-lg); background:var(--c-bg); border:1px solid var(--c-line); }
.d24 .why .ic{ width:50px; height:50px; border-radius:var(--r); background:var(--c-ink); color:#fff; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:16px; }
.d24 .why h3{ font-size:18px; font-weight:800; margin-bottom:8px; }
.d24 .why p{ color:var(--c-text-sub); font-size:14px; }

/* 통계 — 잉크 밴드 */
.d24 .stats{ background:var(--c-ink); color:#fff; }
.d24 .stats .g{ display:grid; grid-template-columns:repeat(2,1fr); gap:32px 16px; } @media(min-width:768px){ .d24 .stats .g{ grid-template-columns:repeat(4,1fr); } }
.d24 .stats .g>div{ padding-left:18px; border-left:1px solid rgba(255,255,255,.16); }
.d24 .stats .num{ font-size:clamp(32px,5vw,52px); font-weight:800; color:#fff; line-height:1.05; letter-spacing:-.04em; font-variant-numeric:tabular-nums; }
.d24 .stats .num u{ font-size:.5em; color:#7DD3FC; text-decoration:none; }
.d24 .stats .lbl{ margin-top:10px; font-weight:700; color:#fff; font-size:15px; }
.d24 .stats .note{ margin-top:4px; font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:rgba(255,255,255,.5); }

/* 절차 스텝 */
.d24 .stepc{ position:relative; background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-lg); padding:30px 20px 24px; }
.d24 .stepc .n{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--c-primary); letter-spacing:.05em; }
.d24 .stepc .ic{ font-size:34px; display:block; margin:14px 0 12px; }
.d24 .stepc h3{ font-size:18px; font-weight:800; margin-bottom:6px; }
.d24 .stepc p{ color:var(--c-text-sub); font-size:13.5px; }

/* 팁 카드 */
.d24 .tip{ display:flex; flex-direction:column; background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-lg); overflow:hidden; transition:transform .2s,box-shadow .2s; }
.d24 .tip:hover{ transform:translateY(-4px); box-shadow:var(--sh); }
.d24 .tip .thumb{ aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; font-size:44px; border-bottom:1px solid var(--c-line); }
.d24 .tip .b{ padding:20px; display:flex; flex-direction:column; gap:9px; flex:1; }
.d24 .tip .cat{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.06em; color:var(--c-text-sub); text-transform:uppercase; }
.d24 .tip h3{ font-size:18px; font-weight:800; } .d24 .tip p{ color:var(--c-text-sub); font-size:14px; flex:1; }
.d24 .tip .more{ font-size:13px; font-weight:700; color:var(--c-primary); }

/* 후기 카드 */
.d24 .rev{ background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-lg); padding:22px; display:flex; flex-direction:column; gap:10px; }
.d24 .rev.new{ animation:d24in .4s var(--ease); }
@keyframes d24in{ from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }
.d24 .rev .stars{ color:var(--c-star); letter-spacing:2px; font-size:14px; }
.d24 .rev .stars u{ color:var(--c-line-strong); text-decoration:none; }
.d24 .rev h4{ font-size:16px; font-weight:800; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.d24 .rev p{ color:var(--c-text-sub); font-size:14px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.d24 .rev .meta{ border-top:1px solid var(--c-line); padding-top:12px; font-family:var(--mono); font-size:11px; letter-spacing:.02em; color:var(--c-text-faint); margin-top:auto; }
.d24 .rev .meta b{ color:var(--c-text); font-family:var(--font); font-weight:700; }
/* 후기 사진 — 목록/우수는 고정 크기 한 줄(최대 4장, 초과 +N) */
.d24 .revfoto{ display:flex; gap:6px; }
.d24 .revfoto .rfcell{ position:relative; width:84px; height:84px; flex:0 0 auto; }
.d24 .revfoto img{ width:100%; height:100%; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--c-line); background:var(--c-bg-soft); cursor:zoom-in; }
.d24 .revfoto .rf-more{ position:absolute; inset:0; background:rgba(13,34,53,.55); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:15px; border-radius:var(--r-sm); cursor:zoom-in; }
.d24 .filepick{ min-height:auto; padding:12px 14px; font-size:14px; cursor:pointer; }
.d24 .filepick::-webkit-file-upload-button,.d24 .filepick::file-selector-button{ font-family:inherit; font-weight:700; font-size:13px; color:var(--c-ink); background:var(--c-bg-soft); border:1px solid var(--c-line-strong); border-radius:var(--r-pill); padding:8px 14px; margin-right:12px; cursor:pointer; }
.d24 .rev .badge{ display:inline-block; font-size:11px; font-weight:700; color:var(--c-ink); background:var(--c-bg-soft); padding:3px 10px; border-radius:var(--r-pill); }
.d24 .rev .best{ color:#fff; background:var(--c-ink); }
.d24 .rev .vchip{ color:var(--c-accent-strong); background:var(--c-accent-weak); }

/* 빈 상태 (첫 후기 유도) */
.d24 .empty{ grid-column:1/-1; text-align:center; padding:clamp(40px,7vw,72px) 24px; border:1.5px dashed var(--c-line-strong); border-radius:var(--r-xl); background:var(--c-bg); }
.d24 .empty .big{ font-size:54px; margin-bottom:14px; }
.d24 .empty h3{ font-size:clamp(20px,3vw,26px); font-weight:800; margin-bottom:10px; }
.d24 .empty p{ color:var(--c-text-sub); font-size:15px; margin-bottom:24px; max-width:42ch; margin-left:auto; margin-right:auto; }

/* 폼 */
.d24 .field{ display:block; margin-bottom:16px; }
.d24 .field>span{ display:block; font-size:13.5px; font-weight:700; color:var(--c-text-sub); margin-bottom:7px; }
.d24 .field>span .req{ color:var(--c-primary); }
.d24 .ctrl{ width:100%; min-height:54px; padding:14px 16px; border:1.5px solid var(--c-line-strong); border-radius:var(--r-sm); font-family:inherit; font-size:16px; color:var(--c-text); background:var(--c-bg); outline:none; transition:border-color .15s,box-shadow .15s; }
.d24 textarea.ctrl{ min-height:112px; resize:vertical; }
.d24 select.ctrl{ -webkit-appearance:none; appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6253' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; }
.d24 .ctrl:focus{ border-color:var(--c-ink); box-shadow:0 0 0 3px var(--c-bg-sunken); }
.d24 .hint{ font-size:12px; color:var(--c-text-faint); margin-top:7px; }
.d24 .chips{ display:flex; flex-wrap:wrap; gap:8px; }
.d24 .chip{ padding:11px 17px; min-height:46px; font-size:14px; font-weight:700; border-radius:var(--r-pill); color:var(--c-text); background:var(--c-bg); border:1.5px solid var(--c-line-strong); transition:.15s var(--ease); }
.d24 .chip.on{ color:#fff; background:var(--c-ink); border-color:var(--c-ink); }
.d24 .inline{ display:flex; gap:10px; align-items:flex-end; }
/* 주소 찾기 버튼 (카카오/다음 우편번호) */
.d24 .addrbtn{ width:100%; min-height:54px; display:flex; align-items:center; gap:12px; padding:12px 14px 12px 16px; border:1.5px solid var(--c-line-strong); border-radius:var(--r-sm); background:var(--c-bg); text-align:left; transition:border-color .15s,box-shadow .15s; }
.d24 .addrbtn:hover{ border-color:var(--c-ink); }
.d24 .addrbtn .av{ flex:1; font-size:15px; color:var(--c-text-faint); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.d24 .addrbtn.filled .av{ color:var(--c-text); font-weight:600; }
.d24 .addrbtn .ab{ flex:0 0 auto; font-size:13px; font-weight:700; color:var(--c-primary); white-space:nowrap; }

/* 위저드 */
.d24 .wiz{ max-width:600px; margin:0 auto; background:var(--c-bg); border:1px solid var(--c-line); border-radius:var(--r-xl); padding:clamp(24px,3.5vw,38px); box-shadow:var(--sh-sm); }
.d24 .wiz .top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.d24 .wiz .top h3{ font-size:21px; font-weight:800; white-space:nowrap; }
.d24 .wiz .cnt{ font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.06em; color:var(--c-text-faint); }
.d24 .wiz .track{ height:4px; border-radius:999px; background:var(--c-bg-sunken); overflow:hidden; }
.d24 .wiz .fill{ height:100%; background:var(--c-ink); border-radius:999px; transition:width .4s var(--ease); }
.d24 .wiz .steps{ display:flex; justify-content:space-between; margin:10px 0 24px; }
.d24 .wiz .steps span{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.02em; display:flex; align-items:center; gap:5px; color:var(--c-text-faint); }
.d24 .wiz .steps span.active{ color:var(--c-ink); } .d24 .wiz .steps span.done{ color:var(--c-primary); }
.d24 .wiz .body{ min-height:212px; }
.d24 .wiz .q{ font-weight:800; font-size:18px; letter-spacing:-.02em; margin-bottom:18px; color:var(--c-ink); }
.d24 .wiz .opts{ display:grid; grid-template-columns:1fr; gap:10px; }
.d24 .wiz .opt{ display:flex; align-items:center; gap:14px; padding:16px; border-radius:var(--r-sm); text-align:left; color:var(--c-text); background:var(--c-bg); border:1.5px solid var(--c-line-strong); transition:.15s var(--ease); }
.d24 .wiz .opt .ic{ font-size:26px; flex:0 0 auto; }
.d24 .wiz .opt .tx b{ display:block; font-size:15px; font-weight:800; color:var(--c-ink); }
.d24 .wiz .opt .tx small{ color:var(--c-text-sub); font-size:13px; }
.d24 .wiz .opt .rd{ margin-left:auto; width:22px; height:22px; border-radius:50%; border:2px solid var(--c-line-strong); flex:0 0 auto; }
.d24 .wiz .opt.on{ background:var(--c-bg); border-color:var(--c-ink); }
.d24 .wiz .opt.on .rd{ border-color:var(--c-ink); background:radial-gradient(circle,var(--c-ink) 42%,transparent 46%); }
.d24 .wiz .foot{ display:flex; gap:12px; margin-top:24px; }
.d24 .wiz .arrow{ padding-bottom:16px; color:var(--c-text-faint); font-weight:800; }
.d24 .wiz .summary{ background:var(--paper); border:1px solid var(--c-line); border-radius:var(--r); padding:18px; display:grid; gap:9px; }
.d24 .wiz .summary .sr{ display:flex; justify-content:space-between; gap:12px; font-size:14px; }
.d24 .wiz .summary .sr span{ color:var(--c-text-sub); } .d24 .wiz .summary .sr b{ color:var(--c-ink); text-align:right; }

/* 캘린더 */
.d24 .cal{ border:1px solid var(--c-line); border-radius:var(--r); padding:18px; background:var(--c-bg); }
.d24 .cal .legend{ display:flex; gap:16px; flex-wrap:wrap; font-size:12px; color:var(--c-text-sub); margin-bottom:14px; padding-bottom:14px; border-bottom:1px solid var(--c-line); }
.d24 .cal .legend span{ white-space:nowrap; }
.d24 .cal .legend i{ width:8px; height:8px; border-radius:50%; display:inline-block; margin-right:5px; vertical-align:middle; }
.d24 .cal .mtitle{ font-weight:800; font-size:15px; margin:8px 0 10px; letter-spacing:-.02em; }
/* 달력 월 이동 */
.d24 .cal .calnav{ display:flex; align-items:center; justify-content:space-between; margin:4px 0 12px; }
.d24 .cal .calnav .calttl{ font-weight:800; font-size:16px; letter-spacing:-.02em; color:var(--c-ink); }
.d24 .cal .cnav{ width:38px; height:38px; border-radius:var(--r-sm); border:1.5px solid var(--c-line-strong); background:var(--c-bg); color:var(--c-ink); font-size:20px; line-height:1; display:flex; align-items:center; justify-content:center; transition:.15s; }
.d24 .cal .cnav:hover:not([disabled]){ border-color:var(--c-ink); background:var(--c-ink); color:#fff; }
.d24 .cal .cnav[disabled]{ opacity:.35; pointer-events:none; }
.d24 .cal .grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.d24 .cal .dow{ text-align:center; font-family:var(--mono); font-size:11px; color:var(--c-text-faint); padding:6px 0; }
.d24 .cal .day{ position:relative; aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:14px; border-radius:9px; color:var(--c-text); transition:.12s; font-variant-numeric:tabular-nums; }
.d24 .cal .day.pad{ color:transparent; pointer-events:none; }
.d24 .cal .day.off{ color:var(--c-line-strong); pointer-events:none; }
.d24 .cal .day:not(.pad):not(.off):hover{ background:var(--c-bg-soft); }
.d24 .cal .day.sel{ background:var(--c-ink); color:#fff; font-weight:800; }
.d24 .cal .day .mk{ position:absolute; bottom:6px; width:5px; height:5px; border-radius:50%; }
.d24 .cal .day.sun{ color:var(--c-danger); } .d24 .cal .day.sat{ color:var(--c-primary); }
.d24 .cal .day.sel.sun,.d24 .cal .day.sel.sat{ color:#fff; }

/* FAQ */
.d24 .faqs{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--c-line); }
.d24 .faq{ border-bottom:1px solid var(--c-line); transition:.2s; }
.d24 .faq .qbtn{ width:100%; display:flex; align-items:center; gap:14px; padding:24px 6px; font-weight:700; font-size:17px; letter-spacing:-.02em; color:var(--c-ink); text-align:left; }
.d24 .faq .qbtn .qq{ font-family:var(--mono); font-size:13px; color:var(--c-primary); font-weight:600; }
.d24 .faq .qbtn .pm{ margin-left:auto; font-size:24px; color:var(--c-text-faint); transition:transform .25s var(--ease); line-height:1; }
.d24 .faq.open .qbtn .pm{ transform:rotate(45deg); color:var(--c-ink); }
.d24 .faq .ans{ max-height:0; overflow:hidden; transition:max-height .28s var(--ease); }
.d24 .faq .ans .inner{ padding:0 6px 24px 34px; color:var(--c-text-sub); font-size:15px; line-height:1.75; }

/* 탭 / 페이지네이션 */
.d24 .tabs{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:26px; }
.d24 .tabs button{ padding:10px 18px; border-radius:var(--r-pill); font-weight:700; font-size:14px; color:var(--c-text-sub); background:transparent; border:1px solid var(--c-line-strong); transition:.15s; }
.d24 .tabs button:hover{ border-color:var(--c-ink); color:var(--c-ink); }
.d24 .tabs button.on{ color:#fff; background:var(--c-ink); border-color:var(--c-ink); }
.d24 .pager{ display:flex; gap:6px; justify-content:center; margin-top:36px; }
.d24 .pager button{ width:42px; height:42px; border-radius:var(--r-sm); font-weight:700; color:var(--c-text-sub); background:transparent; border:1px solid var(--c-line); font-variant-numeric:tabular-nums; }
.d24 .pager button.on{ color:#fff; background:var(--c-ink); border-color:var(--c-ink); }

/* CTA — 잉크 밴드 */
.d24 .cta .box{ display:flex; flex-direction:column; gap:24px; align-items:flex-start; text-align:left; background:var(--c-ink); color:#fff; border-radius:var(--r-xl); padding:clamp(34px,6vw,60px); position:relative; overflow:hidden; }
.d24 .cta .box::after{ content:""; position:absolute; right:-10%; bottom:-60%; width:50%; height:160%; background:radial-gradient(closest-side,rgba(14,151,217,.30),transparent 70%); }
.d24 .cta .box h2{ color:#fff; font-size:clamp(26px,4vw,42px); font-weight:800; margin-bottom:10px; position:relative; z-index:1; }
.d24 .cta .box p{ opacity:.74; font-size:clamp(16px,2.2vw,20px); position:relative; z-index:1; }
.d24 .cta .btns{ display:flex; flex-wrap:wrap; gap:12px; position:relative; z-index:1; }
@media(min-width:768px){ .d24 .cta .box{ flex-direction:row; justify-content:space-between; align-items:center; } }

/* 푸터 */
.d24 .ftr{ background:var(--c-ink); color:rgba(255,255,255,.6); padding:64px 0 28px; }
.d24 .ftr .top{ display:grid; gap:36px; } @media(min-width:768px){ .d24 .ftr .top{ grid-template-columns:1.4fr 2fr; } }
.d24 .ftr b.brand{ color:#fff; font-size:20px; letter-spacing:-.03em; display:block; margin-bottom:14px; }
.d24 .ftr .tel{ color:#fff; font-weight:800; font-size:22px; display:block; margin-top:10px; font-variant-numeric:tabular-nums; }
.d24 .ftr .cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.d24 .ftr .cols h4{ color:#fff; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:600; margin-bottom:14px; }
.d24 .ftr .cols a{ display:block; padding:6px 0; font-size:14px; }
.d24 .ftr .cols a:hover{ color:#fff; }
.d24 .ftr .biz{ border-top:1px solid rgba(255,255,255,.12); margin-top:40px; padding-top:24px; font-family:var(--mono); font-size:11px; opacity:.5; line-height:1.8; }

/* 플로팅 / 하단 고정 */
.d24 .fab{ position:fixed; z-index:60; right:22px; bottom:22px; display:flex; flex-direction:column; gap:12px; align-items:flex-end; }
.d24 .fab a{ display:inline-flex; align-items:center; justify-content:center; font-weight:700; border-radius:var(--r-pill); box-shadow:var(--sh); height:54px; padding:0 24px; color:#fff; }
.d24 .fab .call{ background:var(--c-ink); } .d24 .fab .quote{ background:var(--c-primary); box-shadow:var(--sh-brand); }
.d24 .fab .kakao{ background:#FEE500; color:#181600; }
@media(max-width:767px){ .d24 .fab{ left:0; right:0; bottom:0; flex-direction:row; gap:0; } .d24 .fab a{ flex:1; border-radius:0; height:58px; box-shadow:none; } }

/* 토스트 */
.d24-toast{ position:fixed; left:50%; bottom:92px; transform:translateX(-50%) translateY(20px); background:var(--c-ink); color:#fff; padding:14px 26px; border-radius:var(--r-pill); font-size:14px; font-weight:600; opacity:0; pointer-events:none; transition:.3s var(--ease); z-index:200; font-family:var(--font); box-shadow:var(--sh); max-width:90vw; text-align:center; }
.d24-toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* 모달 */
.d24 .modal{ position:fixed; inset:0; z-index:150; display:none; align-items:center; justify-content:center; padding:20px; }
.d24 .modal.open{ display:flex; }
.d24 .modal .dim{ position:absolute; inset:0; background:rgba(22,19,14,.55); }
.d24 .modal .card{ position:relative; background:var(--c-bg); border-radius:var(--r-xl); width:100%; max-width:560px; max-height:90vh; overflow-y:auto; box-shadow:var(--sh-lg); animation:d24in .3s var(--ease); }
.d24 .modal .mhead{ display:flex; align-items:center; justify-content:space-between; padding:24px 26px; border-bottom:1px solid var(--c-line); position:sticky; top:0; background:var(--c-bg); }
.d24 .modal .mhead h3{ font-size:19px; font-weight:800; } .d24 .modal .mhead .x{ font-size:22px; color:var(--c-text-sub); width:38px; height:38px; border-radius:50%; }
.d24 .modal .mbody{ padding:26px; }

/* 후기 카드 클릭 / 사진 확대 */
.d24 .rev{ cursor:pointer; }
.d24 .revfoto img{ cursor:zoom-in; }
/* 상세 모달 내 배지·별점 (.rev 밖에서도 동일하게 보이도록) */
.d24 .mbody .badge{ display:inline-block; font-size:11px; font-weight:700; color:var(--c-ink); background:var(--c-bg-soft); padding:3px 10px; border-radius:var(--r-pill); }
.d24 .mbody .badge.best{ color:#fff; background:var(--c-ink); }
.d24 .mbody .badge.vchip{ color:var(--c-accent-strong); background:var(--c-accent-weak); }
.d24 .mbody .stars u{ color:var(--c-line-strong); text-decoration:none; }
.d24 .detail-photos{ display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:8px; margin:16px 0 4px; }
.d24 .detail-photos img{ width:100%; aspect-ratio:1; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--c-line); background:var(--c-bg-soft); cursor:zoom-in; }
/* 라이트박스(사진 확대) */
.d24 .lightbox{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,.88); padding:24px; cursor:zoom-out; }
.d24 .lightbox.open{ display:flex; }
.d24 .lightbox img{ max-width:96vw; max-height:92vh; object-fit:contain; border-radius:8px; box-shadow:0 12px 48px rgba(0,0,0,.55); }
.d24 .lightbox .lb-x{ position:absolute; top:16px; right:22px; color:#fff; font-size:30px; line-height:1; cursor:pointer; }

/* 후기 블록 에디터 (블로그형 작성) */
.d24 .editor{ display:flex; flex-direction:column; gap:8px; margin-top:8px; }
.d24 .eb{ position:relative; }
.d24 .eb-text textarea{ width:100%; min-height:84px; resize:none; overflow:hidden; border:1px solid var(--c-line); border-radius:var(--r-sm); padding:12px 38px 12px 14px; font:inherit; font-size:15px; line-height:1.7; background:var(--c-bg); color:var(--c-text); }
.d24 .eb-text textarea:focus{ outline:none; border-color:var(--c-primary); }
.d24 .eb-img img{ width:100%; max-height:360px; object-fit:contain; border-radius:var(--r-sm); border:1px solid var(--c-line); background:var(--c-bg-soft); display:block; }
.d24 .eb .eb-del{ position:absolute; top:8px; right:8px; width:26px; height:26px; border-radius:50%; background:rgba(13,34,53,.6); color:#fff; font-size:13px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.d24 .editor-tools{ display:flex; gap:8px; margin-top:10px; }
.d24 .editor-tools .btn{ flex:1; }
/* 블로그형 후기 본문 (상세 모달) */
.d24 .blogbody p{ color:var(--c-text-sub); font-size:15px; line-height:1.85; white-space:pre-wrap; margin:0 0 10px; }
.d24 .blogbody img.blogimg{ width:100%; border-radius:var(--r-sm); border:1px solid var(--c-line); margin:12px 0; display:block; cursor:zoom-in; }
/* 리치 에디터(SunEditor) — 모달 안 배치 + 표시 본문 */
.d24 .sun-editor{ margin-top:8px; border-radius:var(--r-sm); }
.d24 .sun-editor-editable.blogbody{ padding:0; color:var(--c-text-sub); font-size:15px; line-height:1.8; }
.d24 .sun-editor-editable.blogbody img{ max-width:100%; height:auto; border-radius:var(--r-sm); cursor:zoom-in; }
.d24 .sun-editor-editable.blogbody p{ margin:0 0 10px; }
/* 후기 작성 모달: 작성 단계(.wide)에서 넓고 크게 — 게시글 쓰기 편하게 (상세 모달은 기존 유지) */
.d24 #rev-modal.wide .card{ max-width:960px; max-height:94vh; }
.d24 #rev-modal.wide .mbody{ padding:24px 30px 30px; }
.d24 #rev-modal.wide .sun-editor{ min-height:400px; }
/* 모바일: 작성 모달 전체화면 */
@media (max-width:680px){
  .d24 #rev-modal{ padding:0; }
  .d24 #rev-modal .card{ max-width:100%; width:100%; height:100%; max-height:100%; border-radius:0; }
  .d24 #rev-modal .mhead{ padding:16px 18px; }
  .d24 #rev-modal.wide .mbody{ padding:18px 16px 32px; }
  .d24 #rev-modal.wide .sun-editor{ min-height:48vh; }
}

/* 알림 박스 */
.d24 .notice{ display:flex; gap:10px; align-items:flex-start; background:var(--paper); border:1px solid var(--c-line); border-radius:var(--r-sm); padding:14px 16px; font-size:13px; color:var(--c-text-sub); margin-bottom:20px; }
.d24 .notice .i{ color:var(--c-primary); font-weight:800; }
.d24 .ok{ color:var(--c-success); font-weight:700; }

/* 별점 입력 */
.d24 .starpick{ display:flex; gap:5px; }
.d24 .starpick button{ font-size:32px; line-height:1; color:var(--c-line-strong); transition:color .12s,transform .12s; }
.d24 .starpick button.on{ color:var(--c-star); }
.d24 .starpick button:hover{ transform:scale(1.15); }

@media(prefers-reduced-motion:reduce){ .d24 *{ animation:none !important; transition:none !important; } }
