/* ============================================================
   8FUN 샤워부스시공 — style.css
   오버진(#3A2C3F) + 샴페인골드(#B08D57) / 각진 디자인 / Noto Sans KR
   ============================================================ */
:root{
  --primary:#3A2C3F;
  --primary-dark:#2A1F2E;
  --primary-light:#574459;
  --secondary:#B08D57;
  --secondary-dark:#957439;
  --accent:#8C6A8E;
  --bg:#ffffff;
  --bg-cream:#faf7f4;
  --bg-sand:#f3ede9;
  --bg-beige:#ece4dd;
  --text-dark:#22202a;
  --text-body:#4a4654;
  --text-light:#8b8693;
  --border:rgba(0,0,0,.08);
  --radius:0px;
  --shadow-sm:0 1px 2px -1px rgba(34,32,42,.10),0 2px 6px -2px rgba(34,32,42,.06);
  --shadow:0 4px 12px -4px rgba(34,32,42,.12),0 10px 28px -10px rgba(34,32,42,.10);
  --shadow-lg:0 10px 24px -8px rgba(34,32,42,.18),0 26px 60px -20px rgba(34,32,42,.18);
  --transition:all .35s cubic-bezier(.4,0,.2,1);
  --font-display:'Manrope',-apple-system,BlinkMacSystemFont,'Noto Sans KR',sans-serif;
  --font-body:-apple-system,BlinkMacSystemFont,'Noto Sans KR','Malgun Gothic',sans-serif;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.78;color:var(--text-body);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
strong{color:var(--text-dark);font-weight:700}
h1,h2,h3{font-family:var(--font-display);color:var(--text-dark);font-weight:800;letter-spacing:-.02em;line-height:1.25}

/* ===== 공통 레이아웃 ===== */
.section-padding{padding:clamp(56px,9vw,110px) 0}
.section-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.section-narrow{max-width:820px}
.section-alt{background:var(--bg-cream)}
.kicker{display:inline-block;font-family:var(--font-display);font-size:clamp(11px,1.4vw,13px);font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--secondary-dark);margin-bottom:14px}
.kicker-light{color:#e9d9c2}
.section-title{font-size:clamp(25px,4.4vw,42px);margin-bottom:14px}
.section-lead{font-size:clamp(15px,1.9vw,18px);color:var(--text-body);max-width:680px;margin-bottom:clamp(28px,4vw,48px)}
.intro-lead{max-width:840px;line-height:1.95}
.center-cta{text-align:center;margin-top:clamp(28px,4vw,44px)}

/* ===== 버튼 ===== */
.btn-primary,.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:clamp(15px,1.8vw,17px);padding:clamp(13px,1.6vw,17px) clamp(26px,3.4vw,40px);cursor:pointer;border:2px solid transparent;transition:var(--transition);line-height:1}
.btn-primary{background:var(--secondary);color:#fff}
.btn-primary:hover{background:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--text-dark);border-color:var(--text-dark)}
.btn-outline:hover{background:var(--text-dark);color:#fff;transform:translateY(-2px)}

/* ===== 헤더 ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:64px;display:flex;align-items:center;transition:background .3s ease,box-shadow .3s ease}
.header-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px);display:flex;align-items:center;justify-content:space-between}
.header-logo{display:flex;align-items:center;gap:10px}
.logo-svg{stroke:#fff;transition:stroke .3s ease;flex-shrink:0}
.header-logo-name{color:#fff;font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-.01em;transition:color .3s ease}
.header-logo-kr{font-weight:600;opacity:.9;font-size:15px}
.header-nav{display:flex;gap:clamp(18px,2.6vw,32px);align-items:center}
.header-nav a{color:#fff;font-weight:600;font-size:15px;transition:color .3s ease,opacity .2s ease}
.header-nav a:hover{opacity:.75}
.header-cta{background:var(--secondary);color:#fff!important;font-weight:700;font-size:14px;padding:9px 20px;transition:var(--transition)}
.header-cta:hover{background:var(--secondary-dark);opacity:1!important}
.site-header.scrolled{background:#fff;box-shadow:0 1px 0 var(--border),0 8px 28px -12px rgba(34,32,42,.18)}
.site-header.scrolled .logo-svg{stroke:var(--primary)}
.site-header.scrolled .header-logo-name,.site-header.scrolled .header-nav a{color:var(--primary)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle-bar{width:24px;height:2px;background:#fff;transition:var(--transition)}
.site-header.scrolled .mobile-toggle-bar{background:var(--primary)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;color:var(--primary);padding:8px 12px;z-index:2000}

/* ===== 모바일 메뉴 ===== */
.mobile-menu{position:fixed;inset:0;background:var(--primary);z-index:1500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{color:#fff;font-family:var(--font-display);font-size:22px;font-weight:700}
.mobile-menu-cta{background:var(--secondary);padding:12px 32px;margin-top:8px}
.mobile-menu-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;cursor:pointer}

/* ===== Hero (메인) ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--primary-dark)}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;animation:kenburns 7s ease-out both}
.hero-slide.active img{animation:kenburns 7s ease-out both}
@keyframes kenburns{from{transform:scale(1.07)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,22,32,.55),rgba(28,22,32,.62))}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px);color:#fff}
.hero-title{font-size:clamp(36px,7vw,72px);color:#fff;margin-bottom:18px;line-height:1.1}
.hero-sub{font-size:clamp(16px,2.3vw,22px);color:#f0e8df;margin-bottom:18px;font-weight:500}
.hero-note{font-size:clamp(13px,1.6vw,15px);color:#d9cfc4;line-height:1.85;margin-bottom:30px;max-width:520px}
.hero-cta{margin-bottom:26px}
.hero-dots{display:flex;gap:10px}
.hero-dots button{width:34px;height:4px;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:var(--transition)}
.hero-dots button.active{background:var(--secondary);width:48px}

/* ===== 페이지 히어로 ===== */
.page-hero{background:var(--primary);color:#fff;padding:clamp(110px,16vw,160px) 0 clamp(46px,7vw,72px)}
.page-hero-title{font-size:clamp(30px,5.2vw,52px);color:#fff;margin-bottom:14px}
.page-hero-sub{font-size:clamp(15px,2vw,18px);color:#e6dccf;max-width:640px}
.error-hero{min-height:70vh;display:flex;align-items:center}
.error-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.error-hero .btn-outline{color:#fff;border-color:#fff}

/* ===== 시공사례 그리드 (메인) ===== */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px)}
.case-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.case-ba{display:grid;grid-template-columns:1fr 1fr;gap:2px;overflow:hidden}
.case-ba-item{position:relative;overflow:hidden}
.case-ba-item img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s ease}
.case-card:hover .case-ba-item img{transform:scale(1.05)}
.case-ba-item figcaption{position:absolute;left:8px;top:8px;font-size:11px;font-weight:700;color:#fff;background:rgba(28,22,32,.62);backdrop-filter:blur(4px);padding:3px 8px}
.case-meta{padding:18px 18px 20px;display:flex;flex-direction:column;gap:6px}
.case-cat{font-size:12px;font-weight:700;color:var(--secondary-dark);letter-spacing:.04em}
.case-title{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--text-dark)}
.case-more{margin-top:6px;font-size:13px;font-weight:700;color:var(--primary)}
.empty-note{text-align:center;color:var(--text-light);padding:60px 0;font-size:16px}

/* ===== 서비스 카드 ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px)}
.svc-grid-3{grid-template-columns:repeat(3,1fr)}
.svc-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column;position:relative}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.svc-thumb{overflow:hidden;aspect-ratio:10/7}
.svc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.svc-card:hover .svc-thumb img{transform:scale(1.05)}
.svc-icon{position:absolute;top:14px;left:14px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:var(--secondary)}
.svc-name{font-size:clamp(18px,2.2vw,21px);padding:20px 20px 0}
.svc-desc{padding:8px 20px 0;color:var(--text-body);font-size:15px;line-height:1.7;flex:1}
.svc-more{padding:14px 20px 22px;font-size:13px;font-weight:700;color:var(--primary)}

/* ===== 신뢰 섹션 ===== */
.trust-section{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;padding:clamp(56px,9vw,104px) 0}
.trust-title{color:#fff}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px);margin-top:clamp(28px,4vw,46px)}
.trust-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(6px);padding:clamp(20px,2.6vw,30px);text-align:left}
.trust-ic{color:var(--secondary);margin-bottom:14px}
.trust-name{font-family:var(--font-display);font-size:clamp(16px,2vw,19px);font-weight:800;color:#fff;margin-bottom:8px}
.trust-text{font-size:14px;color:#ddd2e0;line-height:1.7}

/* ===== FAQ 아코디언 ===== */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);background:#fff;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;background:none;border:none;cursor:pointer;padding:clamp(16px,2.2vw,22px);font-family:var(--font-display);font-size:clamp(15px,1.9vw,18px);font-weight:700;color:var(--text-dark);text-align:left}
.faq-ic{position:relative;width:16px;height:16px;flex-shrink:0}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--secondary-dark);transition:var(--transition)}
.faq-ic::before{top:7px;left:0;width:16px;height:2px}
.faq-ic::after{top:0;left:7px;width:2px;height:16px}
.faq-item.open .faq-ic::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:400px}
.faq-a p{padding:0 clamp(16px,2.2vw,22px) clamp(16px,2.2vw,22px);color:var(--text-body);font-size:15px;line-height:1.85}

/* ===== 지역 그리드 ===== */
.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.8vw,20px)}
.region-card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:var(--transition);position:relative}
.region-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.region-card-thumb{overflow:hidden;aspect-ratio:8/5}
.region-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.region-card:hover .region-card-thumb img{transform:scale(1.06)}
.region-card-num{padding:14px 16px 0;font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.12em;color:var(--secondary-dark)}
.region-card-name{padding:4px 16px 0;font-family:var(--font-display);font-size:clamp(15px,1.9vw,18px);font-weight:800;color:var(--text-dark)}
.region-card-bottom{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 16px}
.region-card-badge{font-size:11px;font-weight:700;color:#fff;background:var(--primary);padding:3px 9px}
.region-card-arrow{color:var(--secondary-dark);font-weight:800}
.region-section{background:var(--bg-cream)}

/* ===== CTA 밴드 ===== */
.cta-band{background:var(--primary);color:#fff;padding:clamp(50px,8vw,90px) 0;text-align:center}
.cta-inner{display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-title{font-size:clamp(24px,4vw,38px);color:#fff}
.cta-sub{font-size:clamp(15px,1.9vw,18px);color:#e6dccf;max-width:560px;margin-bottom:8px}

/* ===== 서비스 상세 ===== */
.svc-hero{min-height:clamp(380px,52vh,560px);display:flex;align-items:center;background-size:cover;background-position:center;color:#fff}
.svc-hero-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:clamp(90px,12vw,40px) clamp(16px,4vw,40px) 0}
.svc-hero-title{font-size:clamp(30px,5.6vw,58px);color:#fff;margin-bottom:14px}
.svc-hero-sub{font-size:clamp(15px,2.1vw,20px);color:#efe6db;max-width:600px;margin-bottom:28px}

/* 피처 카드 */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px)}
.feat-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:clamp(24px,3vw,38px);position:relative;transition:var(--transition)}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat-num{font-family:var(--font-display);font-size:clamp(30px,4vw,46px);font-weight:800;color:var(--bg-beige);line-height:1;margin-bottom:14px}
.feat-card:hover .feat-num{color:var(--secondary)}
.feat-title{font-size:clamp(17px,2.1vw,21px);margin-bottom:10px}
.feat-text{font-size:15px;color:var(--text-body);line-height:1.8}

/* 진단 카드 */
.symp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,1.8vw,20px)}
.symp-card{display:flex;gap:16px;background:#fff;border:1px solid var(--border);padding:clamp(18px,2.4vw,28px);transition:var(--transition)}
.symp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--secondary)}
.symp-card .num{font-family:var(--font-display);font-size:14px;font-weight:800;color:#fff;background:var(--primary);min-width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.symp-title{font-size:clamp(16px,2vw,19px);margin-bottom:6px}
.symp-text{font-size:14.5px;color:var(--text-body);line-height:1.75}

/* 프로세스 */
.proc-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(10px,1.5vw,18px);counter-reset:proc}
.proc-step{position:relative;background:#fff;border:1px solid var(--border);padding:clamp(20px,2.4vw,28px) clamp(16px,2vw,22px);counter-increment:proc}
.proc-step::before{content:counter(proc,decimal-leading-zero);display:block;font-family:var(--font-display);font-size:clamp(22px,3vw,34px);font-weight:800;color:var(--secondary);line-height:1;margin-bottom:12px}
.proc-step::after{content:"";position:absolute;top:50%;right:calc(-1*clamp(10px,1.5vw,18px));width:clamp(10px,1.5vw,18px);height:2px;background:var(--bg-beige)}
.proc-step:last-child::after{display:none}
.proc-step-title{font-size:16px;margin-bottom:8px}
.proc-step-text{font-size:14px;color:var(--text-body);line-height:1.7}

/* 비교 카드 */
.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(16px,2.4vw,26px)}
.method-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:clamp(22px,2.8vw,34px);transition:var(--transition)}
.method-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.method-name{font-size:clamp(18px,2.2vw,22px);margin-bottom:16px;padding-bottom:14px;border-bottom:2px solid var(--bg-beige)}
.method-card .pros li,.method-card .cons li{position:relative;padding-left:24px;font-size:14.5px;line-height:1.7;margin-bottom:8px;color:var(--text-body)}
.method-card .pros li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:7px;border-left:2px solid var(--secondary-dark);border-bottom:2px solid var(--secondary-dark);transform:rotate(-45deg)}
.method-card .cons li::before{content:"";position:absolute;left:2px;top:11px;width:12px;height:2px;background:var(--text-light)}
.method-card .cons{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}

/* 서비스 갤러리 */
.svc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.8vw,20px)}
.svc-gallery-item{position:relative;overflow:hidden;border:1px solid var(--border)}
.svc-gallery-item img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s ease}
.svc-gallery-item:hover img{transform:scale(1.06)}
.svc-gallery-item figcaption{position:absolute;left:0;bottom:0;right:0;font-size:12.5px;font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(28,22,32,.72));padding:24px 14px 12px}

/* ===== 갤러리 페이지 ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px)}
.gallery-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}
.gallery-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gallery-thumb{overflow:hidden;aspect-ratio:7/5}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-card:hover .gallery-thumb img{transform:scale(1.05)}
.gallery-meta{padding:18px 20px 22px;display:flex;flex-direction:column;gap:5px}
.gallery-cat{font-size:12px;font-weight:700;color:var(--secondary-dark)}
.gallery-title{font-size:clamp(17px,2vw,20px)}
.gallery-loc{font-size:13px;color:var(--text-light)}
.gallery-more{margin-top:6px;font-size:13px;font-weight:700;color:var(--primary)}

/* ===== 포트폴리오 상세 ===== */
.pd-hero{min-height:clamp(360px,50vh,540px);display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff}
.pd-hero-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px) clamp(36px,5vw,60px)}
.pd-hero-title{font-size:clamp(28px,5vw,50px);color:#fff;margin-bottom:10px}
.pd-hero-sub{font-size:clamp(14px,1.8vw,17px);color:#e9dfd2}
.ba-compare{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,2vw,22px)}
.ba-col{position:relative;border:1px solid var(--border);overflow:hidden}
.ba-col img{width:100%;aspect-ratio:4/3;object-fit:cover}
.ba-label{position:absolute;top:12px;left:12px;font-family:var(--font-display);font-size:13px;font-weight:800;color:#fff;background:rgba(28,22,32,.7);backdrop-filter:blur(4px);padding:5px 12px}
.ba-label-after{background:var(--secondary)}
.pd-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.8vw,20px)}
.pd-sum-card{background:#fff;border:1px solid var(--border);padding:clamp(18px,2.4vw,26px);text-align:center}
.pd-sum-ic{color:var(--secondary-dark);display:flex;justify-content:center;margin-bottom:10px}
.pd-sum-k{font-size:12px;color:var(--text-light);margin-bottom:5px}
.pd-sum-v{font-family:var(--font-display);font-size:clamp(14px,1.7vw,16px);font-weight:700;color:var(--text-dark)}
.pd-nav{display:flex;align-items:center;justify-content:space-between;gap:16px}
.pd-nav-link{display:flex;flex-direction:column;gap:4px;max-width:40%}
.pd-nav-right{text-align:right;align-items:flex-end}
.pd-nav-dir{font-size:12px;font-weight:700;color:var(--secondary-dark)}
.pd-nav-title{font-family:var(--font-display);font-weight:700;color:var(--text-dark);font-size:15px}
.pd-nav-home{font-weight:700;color:var(--primary);border:1px solid var(--border);padding:10px 22px;background:#fff}

/* ===== 상담 페이지 ===== */
.consult-cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2.2vw,24px);margin-bottom:clamp(24px,3.4vw,40px)}
.consult-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:clamp(28px,4vw,44px) 20px;border:1px solid var(--border);transition:var(--transition);background:#fff}
.consult-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.consult-call{background:var(--primary);color:#fff;border-color:var(--primary)}
.consult-sms{background:var(--secondary);color:#fff;border-color:var(--secondary)}
.consult-ic{margin-bottom:8px}
.consult-k{font-family:var(--font-display);font-size:clamp(17px,2.2vw,21px);font-weight:800}
.consult-v{font-family:var(--font-display);font-size:clamp(18px,2.4vw,24px);font-weight:800;letter-spacing:.02em}
.consult-note{font-size:13px;opacity:.9}
.consult-info-box,.consult-biz{background:var(--bg-cream);border:1px solid var(--border);padding:clamp(22px,3vw,32px);margin-bottom:18px}
.consult-info-title{font-size:clamp(17px,2.2vw,21px);margin-bottom:14px}
.consult-info-list li{position:relative;padding-left:20px;margin-bottom:10px;font-size:15px;line-height:1.8;color:var(--text-body)}
.consult-info-list li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--secondary)}
.consult-biz-info{font-size:15px;line-height:2;color:var(--text-body)}

/* ===== 사이트맵 페이지 ===== */
.sm-controls{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:clamp(24px,3.4vw,40px)}
.sm-search{flex:1;min-width:220px;padding:13px 18px;border:1px solid var(--border);font-size:15px;font-family:var(--font-body);background:#fff}
.sm-search:focus{outline:none;border-color:var(--secondary)}
.sm-filters{display:flex;flex-wrap:wrap;gap:8px}
.sm-filter{font-family:var(--font-display);font-size:13px;font-weight:700;padding:9px 16px;border:1px solid var(--border);background:#fff;color:var(--text-body);cursor:pointer;transition:var(--transition)}
.sm-filter.active,.sm-filter:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.sm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.6vw,16px)}
.sm-card{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);padding:16px 18px;transition:var(--transition)}
.sm-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--secondary)}
.sm-card-ic{color:var(--secondary-dark);display:flex}
.sm-card-body{display:flex;flex-direction:column;gap:2px}
.sm-card-title{font-family:var(--font-display);font-weight:700;color:var(--text-dark);font-size:15px}
.sm-card-cat{font-size:12px;color:var(--text-light)}
.sm-empty{text-align:center;color:var(--text-light);padding:40px 0}

/* ===== 푸터 ===== */
.site-footer{background:var(--primary-dark);color:#cfc6d2;padding:clamp(48px,7vw,80px) 0 30px}
.footer-grid{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px);display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(24px,4vw,48px)}
.footer-brand-name{font-family:var(--font-display);font-size:24px;font-weight:800;color:#fff;margin-bottom:12px}
.footer-brand-sub{font-size:14px;line-height:1.8;color:#b5abbb}
.footer-col-title{font-family:var(--font-display);font-size:14px;font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:.02em}
.footer-link{display:block;font-size:14px;color:#b5abbb;margin-bottom:9px;transition:color .2s ease}
.footer-link:hover{color:var(--secondary)}
.footer-biz{width:100%;max-width:var(--maxw);margin:30px auto 0;padding:24px clamp(16px,4vw,40px) 0;border-top:1px solid rgba(255,255,255,.1)}
.footer-info{font-size:13px;line-height:1.95;color:#9a90a0}
.footer-bottom{width:100%;max-width:var(--maxw);margin:24px auto 0;padding:18px clamp(16px,4vw,40px) 0;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;font-size:13px;color:#9a90a0}
.footer-bottom-links{display:flex;gap:18px}
.footer-bottom-links a:hover{color:var(--secondary)}

/* ===== Floating / Mobile bottom ===== */
.floating-wrap{position:fixed;right:20px;bottom:24px;z-index:900;display:flex;flex-direction:column;gap:12px;align-items:center}
.floating-top-btn{width:46px;height:46px;border:none;background:#fff;color:var(--primary);box-shadow:var(--shadow);cursor:pointer;display:none;align-items:center;justify-content:center}
.floating-top-btn.show{display:flex}
.floating-cta{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:62px;height:62px;background:var(--secondary);color:#fff;font-size:13px;font-weight:700;box-shadow:var(--shadow-lg)}
.floating-cta::before{content:"";position:absolute;inset:0;border:2px solid var(--secondary);animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}
.mobile-bottom{display:none;position:fixed;left:0;right:0;bottom:0;z-index:900;background:#fff;border-top:1px solid var(--border);padding:8px 14px env(safe-area-inset-bottom,8px);flex-direction:column;gap:6px}
.mobile-bottom-steps{display:flex;align-items:center;justify-content:center;gap:8px;font-size:11px;color:var(--text-light)}
.mobile-bottom-steps .now{color:var(--primary);font-weight:700}
.mobile-bottom-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--secondary);color:#fff;font-family:var(--font-display);font-weight:700;font-size:16px;padding:13px}

/* ===== 스크롤 리빌 ===== */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}

/* ============================================================
   반응형 — 1024 / 768 / 560
   ============================================================ */
@media(max-width:1024px){
  .case-grid,.svc-grid,.svc-grid-3,.gallery-grid,.feat-grid,.svc-gallery,.sm-grid{grid-template-columns:repeat(2,1fr)}
  .region-grid{grid-template-columns:repeat(3,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .pd-summary{grid-template-columns:repeat(2,1fr)}
  .proc-steps{grid-template-columns:repeat(2,1fr)}
  .proc-step::after{display:none}
}
@media(max-width:768px){
  .header-nav,.header-cta{display:none}
  .mobile-toggle{display:flex}
  .mobile-bottom{display:flex}
  .floating-wrap{bottom:96px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .symp-grid{grid-template-columns:1fr}
  .ba-compare{grid-template-columns:1fr}
  .consult-cards{grid-template-columns:1fr}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  body{padding-bottom:0}
}
@media(max-width:560px){
  .case-grid,.svc-grid,.svc-grid-3,.gallery-grid,.feat-grid,.svc-gallery,.sm-grid,.trust-grid,.pd-summary,.proc-steps,.region-grid,.footer-grid{grid-template-columns:1fr}
  .case-ba{grid-template-columns:1fr 1fr}
  .hero-title{font-size:clamp(32px,9vw,46px)}
  .method-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
}
