/*
Theme Name: Cleanservice Tile
Theme URI: https://tile.cservicecnter.com
Description: 클린서비스 화장실 타일크랙 구멍메꿈 전문 테마
Author: 클린서비스
Version: 2.8.0
Text Domain: cleanservice-tile
*/

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Noto Sans KR',sans-serif;background:#F5F6F8;color:#111111;font-size:16px;line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}

/* ── VARIABLES ── */
:root{--bg:#F5F6F8;--sub:#A6A29A;--accent:#0052CC;--text:#111111;--hh:72px}

/* ── HEADER ── */
.hd{position:fixed;top:0;left:0;right:0;height:var(--hh);background:rgba(245,246,248,.97);backdrop-filter:blur(10px);border-bottom:1px solid rgba(166,162,154,.18);z-index:1000;transition:box-shadow .3s}
.hd.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.08)}
.hd-in{max-width:1200px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.08rem;letter-spacing:-.02em}
.logo svg{width:38px;height:38px;flex-shrink:0}
.logo span{display:flex;flex-direction:column;gap:1px}
.logo b{color:var(--accent);line-height:1.2}
.logo-sub{font-style:normal;font-size:.58rem;font-weight:600;color:var(--sub);line-height:1;display:block;letter-spacing:.22em;text-transform:uppercase}
.nav{display:none}
.ham{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.ham span{display:block;width:24px;height:2px;background:#111;border-radius:2px;transition:all .3s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-menu{display:block;position:fixed;top:var(--hh);left:0;right:0;background:#F5F6F8;border-bottom:1px solid rgba(166,162,154,.25);padding:8px 20px 20px;z-index:999;opacity:0;transform:translateY(-8px);transition:opacity .3s,transform .3s;pointer-events:none}
.mob-menu.open{opacity:1;transform:translateY(0);pointer-events:all}
.mob-menu a{display:flex;align-items:center;gap:10px;padding:14px 4px;font-size:.95rem;font-weight:500;border-bottom:1px solid rgba(166,162,154,.18);color:#111}
.mob-menu a:last-of-type{border-bottom:none}
.mob-menu a svg{width:17px;height:17px;color:var(--accent)}
.mob-menu .mob-tel-only{display:none}
.mob-menu .mob-pc-only{display:flex}
@media(max-width:768px){
  .mob-menu .mob-tel-only{display:flex}
  .mob-menu .mob-pc-only{display:none}
}

/* ── SECTION BASE ── */
section{padding:88px 24px}
.wrap{max-width:1200px;margin:0 auto}
.sec-ttl{font-size:clamp(1.55rem,3.8vw,2.2rem);font-weight:700;line-height:1.38;text-align:center;word-break:keep-all}
.sec-sub{font-size:.97rem;color:#555;text-align:center;line-height:1.75;margin-top:10px;margin-bottom:50px;word-break:keep-all}
.rotator{position:relative;height:5rem;overflow:hidden;text-align:center;margin-bottom:50px}
.rotator-item{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:clamp(1.55rem,3.8vw,2.2rem);font-weight:700;line-height:1.38;word-break:keep-all;opacity:0;transform:translateY(20px);transition:opacity .45s ease,transform .45s ease}
.rotator-item.active{opacity:1;transform:translateY(0)}
.rotator-item.leaving{opacity:0;transform:translateY(-20px)}
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.fade-in.vis{opacity:1;transform:translateY(0)}

/* ── HERO ── */
.hero{padding-top:var(--hh);min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-bg::after{content:'';position:absolute;inset:0;background:rgba(5,15,35,.52);z-index:1;pointer-events:none}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1}
.hero-cnt{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 24px 50px;width:100%}
.hero h1{font-size:clamp(1.8rem,4.95vw,3.24rem);font-weight:700;color:#fff;line-height:1.22;margin-bottom:18px;word-break:keep-all}
.hero-copy{font-size:clamp(.87rem,1.98vw,1.08rem);color:rgba(255,255,255,.88);margin-bottom:36px;line-height:1.82;max-width:560px;word-break:keep-all}
@media(min-width:769px){
  .hero-cnt{position:absolute;bottom:14%;left:48px;right:auto;top:auto;max-width:600px;width:auto;padding:0;margin:0}
  .hero h1{font-size:clamp(2.4rem,5.5vw,4rem)}
  .hero-tel-btn{display:none}
  .hero-contact-btn{display:inline-flex;align-items:center;margin-top:22px;padding:13px 28px;background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.6);font-size:1rem;font-weight:700;border-radius:50px;text-decoration:none;transition:background .2s}
  .hero-contact-btn:hover{background:rgba(255,255,255,.25)}
  .intro-card{background:transparent;border-radius:0;box-shadow:none}
  .intro-card-top{padding:0;text-align:center}
  .intro-benefits{display:flex;justify-content:center;gap:48px;margin-top:28px}
  .intro-benefit{flex-direction:column;align-items:center;text-align:center;padding:0;border:none;gap:5px}
  .benefit-check{display:none}
  .benefit-body{align-items:center;gap:4px}
  .benefit-lbl{font-size:.8rem}
  .benefit-txt{font-size:.95rem;color:#555;font-weight:400}
}
.btn-hero{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:17px 38px;border-radius:10px;font-size:1.05rem;font-weight:700;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 22px rgba(0,82,204,.45)}
.btn-hero:hover{background:#003fa3;transform:translateY(-2px);box-shadow:0 7px 28px rgba(0,82,204,.55)}
.btn-hero svg{width:18px;height:18px}

/* ── INTRO CARD ── */
.intro-sec{background:var(--bg);padding:48px 24px}
.intro-card{background:#fff;border-radius:18px;box-shadow:0 2px 24px rgba(0,0,0,.08);overflow:hidden}
.intro-card-top{padding:32px 32px 0}
.intro-card-top .rotator{margin-bottom:8px}
.intro-benefits{list-style:none;margin:12px 0 0;padding:0}
.intro-benefit{display:flex;align-items:flex-start;gap:14px;padding:16px 32px;border-top:1px solid rgba(166,162,154,.1)}
.benefit-check{width:22px;height:22px;flex-shrink:0;margin-top:3px}
.benefit-body{display:flex;flex-direction:column;gap:3px}
.benefit-lbl{font-size:.72rem;font-weight:700;color:var(--accent);letter-spacing:.04em}
.benefit-txt{font-size:.97rem;font-weight:500;color:#1a1a1a;line-height:1.5}

/* ── PAIN POINTS ── */
.pain{background:#fff}
.pain-cards-mob{display:none;background:#fff}
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pp-card{background:var(--bg);border-radius:16px;padding:36px 28px;border:1px solid rgba(166,162,154,.22);transition:transform .3s,box-shadow .3s}
.pp-card:hover{transform:translateY(-5px);box-shadow:0 10px 36px rgba(0,0,0,.08)}
.painpoint-card-icon{width:54px;height:54px;background:rgba(0,82,204,.09);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.painpoint-card-icon svg{width:28px;height:28px;color:var(--accent);animation:iconPulse 2.6s ease-in-out infinite}
@keyframes iconPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.28)}}
.pp-tag{font-size:.75rem;font-weight:700;color:var(--accent);background:rgba(0,82,204,.09);padding:3px 11px;border-radius:20px;display:inline-block;margin-bottom:11px}
.pp-card h3{font-size:1.02rem;font-weight:700;margin-bottom:10px;line-height:1.5;word-break:keep-all}
.pp-card p{font-size:.88rem;color:#555;line-height:1.72;word-break:keep-all}

/* ── FULLSCREEN IMAGE ── */
.full-img{width:100%;height:62vh;background-image:url('/image/ex7.jpg');background-size:cover;background-position:center;background-attachment:fixed}

/* ── WHY US ── */
.why,.why-extra{background:var(--bg)}
.why-extra{padding-top:0}
.why{padding-bottom:44px}
.svc-sec{padding-top:44px;padding-bottom:44px}
.faq-sec{padding-top:44px}
.why .sec-ttl{margin-bottom:50px}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:60px}
.why-dots,.svc-dots{display:none}
.why-card{background:#fff;border-radius:16px;padding:36px 28px;border:1px solid rgba(166,162,154,.18);transition:transform .3s,box-shadow .3s}
.why-card:hover{transform:translateY(-5px);box-shadow:0 10px 36px rgba(0,0,0,.08)}
.why-icon{display:none}
.why-card h3{font-size:1.05rem;font-weight:700;margin-bottom:10px;line-height:1.45;word-break:keep-all;padding-left:14px;border-left:3px solid var(--accent)}
.why-card p{font-size:.88rem;color:#555;line-height:1.72;word-break:keep-all}
.qa-block{max-width:800px;margin:0 auto}
.qa-item{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid rgba(166,162,154,.22)}
.qa-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.qa-item h3{font-size:1rem;font-weight:700;color:var(--accent);margin-bottom:10px;word-break:keep-all}
.qa-item p{font-size:.92rem;color:#444;line-height:1.82;word-break:keep-all}

/* ── BEFORE / AFTER ── */
.ba-sec{background:#0d1117;padding:88px 24px}
.ba-sec .sec-ttl{color:#fff}
.ba-sec .sec-sub{color:rgba(255,255,255,.58)}
.ba-wrap{max-width:900px;margin:0 auto;position:relative;border-radius:14px;overflow:hidden;cursor:ew-resize;user-select:none;touch-action:none;aspect-ratio:16/9}
.ba-before,.ba-after{position:absolute;inset:0;background-size:cover;background-position:center}
.ba-before{background-image:url('/image/after-main.jpg');z-index:1}
.ba-after{background-image:url('/image/mainb.jpg');z-index:2;clip-path:inset(0 50% 0 0)}
.ba-div{position:absolute;top:0;left:50%;width:3px;height:100%;background:#fff;z-index:10;transform:translateX(-50%);pointer-events:none}
.ba-handle{position:absolute;top:50%;left:50%;width:46px;height:46px;border-radius:50%;background:#fff;border:3px solid var(--accent);z-index:11;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 18px rgba(0,0,0,.35);cursor:ew-resize}
.ba-handle svg{width:20px;height:20px;color:var(--accent)}
.ba-lbl{position:absolute;top:16px;z-index:5;padding:6px 14px;border-radius:20px;font-size:.78rem;font-weight:700;letter-spacing:.04em}
.ba-lbl-b{left:16px;background:rgba(0,0,0,.72);color:#fff}
.ba-lbl-a{right:16px;background:rgba(0,82,204,.92);color:#fff}
.ba-hint{text-align:center;margin-top:16px;font-size:.83rem;color:rgba(255,255,255,.45);letter-spacing:.02em}

/* ── CASES ── */
.cases-sec{background:#fff}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:42px}
.case-card{border-radius:12px;overflow:hidden;position:relative;display:block;cursor:pointer}
.case-img{width:100%;aspect-ratio:4/3;background-size:cover;background-position:center;position:relative}
.case-img.c1{background-image:url('/image/260605b%20(5).jpg')}
.case-img.c2{background-image:url('/image/260606b%20(2).jpg')}
.case-img.c3{background-image:url('/image/260610b%20(4).jpg')}
.case-overlay{position:absolute;inset:0;background:rgba(0,82,204,.86);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;padding:20px}
.case-card:hover .case-overlay{opacity:1}
.case-overlay h3{color:#fff;font-size:1.05rem;font-weight:700;text-align:center;word-break:keep-all;transform:translateY(10px);transition:transform .3s}
.case-card:hover .case-overlay h3{transform:translateY(0)}
.case-overlay span{color:rgba(255,255,255,.8);font-size:.82rem;margin-top:6px;transform:translateY(10px);transition:transform .3s .05s}
.case-card:hover .case-overlay span{transform:translateY(0)}
.cases-more{text-align:center}
.btn-more{display:inline-block;padding:13px 40px;border:2px solid var(--accent);color:var(--accent);border-radius:8px;font-weight:600;font-size:.92rem;transition:background .2s,color .2s}
.btn-more:hover{background:var(--accent);color:#fff}

/* ── SERVICES ── */
.svc-sec{background:var(--bg)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid rgba(166,162,154,.18);transition:transform .3s,box-shadow .3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 10px 32px rgba(0,0,0,.07)}
.svc-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.svc-body{padding:0}
.svc-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:none;border:none;border-bottom:1px solid transparent;cursor:pointer;text-align:left;gap:8px;transition:border-color .2s}
.svc-toggle[aria-expanded="true"]{border-bottom-color:rgba(166,162,154,.28)}
.svc-ttl-txt{font-size:.93rem;font-weight:700;word-break:keep-all;color:var(--text)}
.svc-chevron{flex-shrink:0;transition:transform .3s ease}
.svc-toggle[aria-expanded="true"] .svc-chevron{transform:rotate(180deg)}
.svc-detail{max-height:0;overflow:hidden;transition:max-height .35s ease}
.svc-detail.open{max-height:180px}
.svc-detail ul{margin:0;padding:12px 16px 16px 16px;list-style:none}
.svc-detail li{font-size:.82rem;color:#666;line-height:1.65;padding-left:1.1em;position:relative;word-break:keep-all}
.svc-detail li::before{content:'·';position:absolute;left:0;color:#0052CC}

/* ── ABOUT ── */
.about-sec{background:#fff}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.about-card{text-align:center;padding:38px 24px;background:var(--bg);border-radius:16px;border:1px solid rgba(166,162,154,.2);transition:transform .3s}
.about-card:hover{transform:translateY(-5px)}
.about-ico{width:66px;height:66px;background:linear-gradient(135deg,#0052CC,#003fa3);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.about-ico svg{width:32px;height:32px;color:#fff}
.about-card h3{font-size:1.02rem;font-weight:700;margin-bottom:10px;word-break:keep-all}
.about-card p{font-size:.87rem;color:#555;line-height:1.72;word-break:keep-all}

/* ── FAQ ── */
.faq-sec{background:var(--bg)}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid rgba(166,162,154,.28);border-radius:10px;margin-bottom:10px;overflow:hidden;background:#fff}
.faq-q{width:100%;background:none;border:none;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;font-family:inherit;text-align:left}
.faq-q-txt{font-size:.93rem;font-weight:600;color:#111;word-break:keep-all;line-height:1.5}
.faq-ico{flex-shrink:0;width:26px;height:26px;background:rgba(0,82,204,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .3s,background .3s}
.faq-ico svg{width:12px;height:12px;color:var(--accent);transition:color .3s}
.faq-item.open .faq-ico{transform:rotate(180deg);background:var(--accent)}
.faq-item.open .faq-ico svg{color:#fff}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-ans-in{padding:0 22px 20px;font-size:.88rem;color:#555;line-height:1.82;word-break:keep-all}
.faq-item.open .faq-ans{max-height:500px}

/* ── CTA ── */
.cta-sec{background:linear-gradient(135deg,#0052CC,#003fa3);padding:88px 24px;text-align:center}
.cta-sec h2{font-size:clamp(1.45rem,3.8vw,2.15rem);font-weight:700;color:#fff;margin-bottom:12px;word-break:keep-all}
.cta-sec p{color:rgba(255,255,255,.82);margin-bottom:38px;font-size:.97rem;word-break:keep-all}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-tel{background:#fff;color:var(--accent);padding:15px 34px;border-radius:10px;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s}
.btn-sms{background:rgba(255,255,255,.14);color:#fff;border:2px solid rgba(255,255,255,.5);padding:13px 32px;border-radius:10px;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s}
.btn-page{background:rgba(255,255,255,.14);color:#fff;border:2px solid rgba(255,255,255,.5);padding:13px 32px;border-radius:10px;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s}
.btn-tel:hover,.btn-sms:hover,.btn-page:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.22)}
.cta-mob{display:none}
.cta-pc{display:flex;justify-content:center}
.cta-txt-mob{display:none}
.cta-txt-pc{display:inline}

/* ── 전화/상담 링크 PC↔모바일 전환 ── */
.link-tel-only{display:none}
.link-contact-only{display:inline}
@media(max-width:768px){
  .link-tel-only{display:inline}
  .link-contact-only{display:none}
}

/* ── FOOTER ── */
.ft{background:#0d1117;color:rgba(255,255,255,.65);padding:44px 24px 28px}
.ft-in{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.ft-info .ft-brand{font-size:.97rem;font-weight:700;color:#fff;margin-bottom:10px}
.ft-info p{font-size:.8rem;margin-bottom:3px;line-height:1.7}
.ft-nav{display:flex;gap:22px;align-items:center}
.ft-nav a{display:flex;align-items:center;gap:6px;font-size:.83rem;color:rgba(255,255,255,.58);transition:color .2s}
.ft-nav a:hover{color:#fff}
.ft-nav svg{width:13px;height:13px}
.ft-bot{max-width:1200px;margin:22px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);font-size:.76rem;color:rgba(255,255,255,.28);text-align:center}

/* ── CASES LIST PAGE ── */
.page-hero{padding-top:var(--hh);background:#fff}
.page-hero-in{max-width:1200px;margin:0 auto;padding:52px 24px 0}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;margin-bottom:10px;word-break:keep-all}
.page-hero p{font-size:.95rem;color:#555;margin-bottom:36px;word-break:keep-all}
.cases-main{padding:48px 24px 88px;background:#fff}
.case-card-full{border-radius:14px;overflow:hidden;display:block;background:#eee;border:1px solid rgba(166,162,154,.18);transition:transform .3s,box-shadow .3s}
.case-card-full:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.1)}
.case-body-card{padding:20px 22px 24px;background:#fff}
.case-body-card .loc{font-size:.76rem;font-weight:700;color:var(--accent);background:rgba(0,82,204,.08);padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:9px}
.case-body-card h2{font-size:1rem;font-weight:700;margin-bottom:7px;word-break:keep-all;line-height:1.45}
.case-body-card p{font-size:.84rem;color:#666;line-height:1.68;word-break:keep-all}
.case-body-card .more{display:inline-flex;align-items:center;gap:4px;font-size:.82rem;font-weight:600;color:var(--accent);margin-top:12px}
.case-body-card .more svg{width:13px;height:13px}

/* ── CASE DETAIL PAGE ── */
.case-hero{padding-top:var(--hh)}
.case-hero-img{width:100%;height:480px;background-size:cover;background-position:center}
.case-body{max-width:800px;margin:0 auto;padding:60px 24px 88px}
.case-tag{display:inline-block;font-size:.75rem;font-weight:700;color:var(--accent);background:rgba(0,82,204,.08);padding:4px 12px;border-radius:20px;margin-bottom:14px}
.case-body h1{font-size:clamp(1.7rem,4vw,2.4rem);font-weight:700;line-height:1.32;margin-bottom:18px;word-break:keep-all}
.case-meta{display:flex;gap:20px;margin-bottom:36px;flex-wrap:wrap}
.case-meta span{font-size:.82rem;color:#888;display:flex;align-items:center;gap:5px}
.case-meta svg{width:13px;height:13px}
.case-imgs{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:36px 0}
.case-img-block{width:100%;aspect-ratio:4/3;border-radius:10px;background-size:cover;background-position:center}
.img-caption{font-size:.78rem;color:#888;text-align:center;margin-top:6px}
.case-body h2{font-size:1.2rem;font-weight:700;margin:36px 0 12px;word-break:keep-all}
.case-body h3{font-size:1rem;font-weight:700;margin:28px 0 8px;word-break:keep-all;color:var(--accent)}
.case-body p{font-size:.93rem;color:#444;line-height:1.85;margin-bottom:16px;word-break:keep-all}
.step-list{margin:16px 0 24px;padding-left:0;list-style:none}
.step-list li{display:flex;gap:12px;margin-bottom:12px;font-size:.9rem;color:#444;line-height:1.7;word-break:keep-all}
.step-num{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.info-box{background:#fff;border:1px solid rgba(0,82,204,.18);border-radius:12px;padding:22px 24px;margin:28px 0}
.info-box h3{font-size:.92rem;font-weight:700;color:var(--accent);margin-bottom:10px}
.info-box p{font-size:.87rem;color:#555;line-height:1.75;margin-bottom:0;word-break:keep-all}
.case-nav{display:flex;justify-content:space-between;margin-top:60px;padding-top:32px;border-top:1px solid rgba(166,162,154,.25);flex-wrap:wrap;gap:14px}
.case-nav a{display:flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600;color:var(--accent)}
.case-nav a svg{width:15px;height:15px}

/* ── CONTACT PAGE ── */
.contact-wrap{padding-top:var(--hh);min-height:100vh}
.contact-hero{background:linear-gradient(135deg,#0052CC,#003fa3);padding:60px 24px}
.contact-hero-in{max-width:800px;margin:0 auto;text-align:center}
.contact-hero h1{font-size:clamp(1.7rem,4vw,2.5rem);font-weight:700;color:#fff;margin-bottom:12px;word-break:keep-all;line-height:1.32}
.contact-hero p{color:rgba(255,255,255,.82);font-size:.97rem;word-break:keep-all}
.contact-main{max-width:800px;margin:0 auto;padding:60px 24px 88px}
.contact-card{background:#fff;border-radius:16px;padding:36px;border:1px solid rgba(166,162,154,.2);margin-bottom:24px}
.contact-card h2{font-size:1.1rem;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px;word-break:keep-all}
.contact-card h2 svg{width:22px;height:22px;color:var(--accent)}
.info-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid rgba(166,162,154,.15)}
.info-row:last-child{border-bottom:none;padding-bottom:0}
.info-lbl{font-size:.8rem;font-weight:700;color:#888;min-width:80px;padding-top:2px}
.info-val{font-size:.95rem;color:#111;line-height:1.6;word-break:keep-all}
.info-val a{color:var(--accent);font-weight:600}
.contact-btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn-tel-lg{display:flex;align-items:center;justify-content:center;gap:9px;background:var(--accent);color:#fff;padding:17px 36px;border-radius:10px;font-size:1.05rem;font-weight:700;transition:background .2s,transform .2s;flex:1;min-width:180px}
.btn-tel-lg:hover{background:#003fa3;transform:translateY(-2px)}
.btn-tel-lg svg{width:20px;height:20px}
.btn-sms-lg{display:flex;align-items:center;justify-content:center;gap:9px;background:#fff;color:var(--accent);border:2px solid var(--accent);padding:15px 36px;border-radius:10px;font-size:1.05rem;font-weight:700;transition:background .2s,color .2s,transform .2s;flex:1;min-width:180px}
.btn-sms-lg:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.btn-sms-lg svg{width:20px;height:20px}
.step-guide{margin-top:12px}
.step-guide-item{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start}
.sg-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:rgba(0,82,204,.08);color:var(--accent);font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.sg-txt h3{font-size:.93rem;font-weight:700;margin-bottom:3px;word-break:keep-all}
.sg-txt p{font-size:.85rem;color:#666;line-height:1.65;word-break:keep-all}
.area-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.area-tag{font-size:.8rem;background:rgba(0,82,204,.07);color:var(--accent);padding:5px 12px;border-radius:20px;font-weight:500}

/* ── SITEMAP PAGE ── */
.sm-wrap{padding-top:var(--hh);max-width:880px;margin:0 auto;padding-left:28px;padding-right:28px;padding-bottom:80px}
.sm-hero{padding:52px 0 40px;text-align:center}
.sm-hero h1{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0 0 8px;color:#111}
.sm-hero p{font-size:.93rem;color:#666;margin:0}
.sm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:32px 28px;align-items:start;margin-bottom:56px}
.sm-group{}
.sm-group-title{font-size:.78rem;font-weight:900;color:#0052CC;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid #0052CC;display:inline-block;letter-spacing:.06em;text-transform:uppercase}
.sm-group-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.sm-group-link{font-size:.875rem;color:#444;display:flex;align-items:center;gap:8px;text-decoration:none;line-height:1.45;transition:color .15s}
.sm-group-link::before{content:'';width:4px;height:4px;background:#0052CC;border-radius:50%;flex-shrink:0}
.sm-group-link:hover{color:#0052CC}
.sm-area-group{border-top:1px solid #eee;padding-top:48px}
.sm-area-list{columns:3;column-gap:20px}
.sm-area-list li{break-inside:avoid;margin-bottom:8px}
@media(max-width:767px){
  .sm-grid{grid-template-columns:1fr;margin-bottom:48px}
  .sm-area-group{padding-top:40px}
  .sm-area-list{columns:2}
  .sm-wrap{padding-left:16px;padding-right:16px;padding-bottom:60px}
}
@media(max-width:480px){
  .sm-area-list{columns:1}
}

/* ── RESTORATION GRID (PC only) ── */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:60px}
.res-pair{display:flex;align-items:stretch;border-radius:10px;overflow:visible;box-shadow:0 2px 12px rgba(0,0,0,.1);background:#fff}
.res-img-wrap{flex:1;position:relative;overflow:visible;min-width:0;border-radius:10px;transition:transform .3s ease,box-shadow .3s ease;z-index:0}
.res-img-wrap:hover{transform:scale(1.18);z-index:10;box-shadow:0 16px 40px rgba(0,0,0,.22)}
.res-img-wrap img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;border-radius:10px}
.res-lbl{position:absolute;top:8px;left:8px;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:4px;color:#fff;letter-spacing:.04em;line-height:1.4}
.res-lbl-b{background:rgba(10,10,10,.58)}
.res-lbl-a{background:rgba(0,82,204,.82)}
.res-arrow{width:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f4f5f7;color:#0052CC}
@media(max-width:768px){.res-grid{display:none}}

/* ── MOBILE BEFORE/AFTER SLIDESHOW ── */
.mob-slide-sec{display:none;padding:0;overflow:hidden}
.mob-slide-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;scroll-behavior:smooth}
.mob-slide-track::-webkit-scrollbar{display:none}
.mob-slide{flex:0 0 100%;scroll-snap-align:start;position:relative}
.mob-slide img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.mob-slide-lbl{position:absolute;bottom:14px;left:14px;padding:5px 12px;border-radius:5px;font-size:.82rem;font-weight:700;color:#fff;letter-spacing:.04em}
.mob-slide-lbl.lbl-b{background:rgba(10,10,10,.55)}
.mob-slide-lbl.lbl-a{background:rgba(0,82,204,.82)}
@media(max-width:767px){
  .mob-slide-sec{display:block;margin:24px 0 36px}
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  section{padding:64px 20px}
  .why{padding-bottom:32px}
  .svc-sec{padding-top:32px}
  .mob-menu{display:block}
  .pain-grid,.about-grid,.cases-grid{grid-template-columns:1fr}
  .why-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;gap:16px;margin-bottom:16px;padding-bottom:4px}
  .why-grid::-webkit-scrollbar{display:none}
  .why-card{flex:0 0 100%;scroll-snap-align:start;min-width:0}
  .why-dots{display:flex;justify-content:center;gap:8px;margin-bottom:0}
  .why-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,82,204,.2);transition:background .25s}
  .why-dot.active{background:#0052CC}
  .svc-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;gap:16px;margin-bottom:16px;padding-bottom:4px}
  .svc-grid::-webkit-scrollbar{display:none}
  .svc-card{flex:0 0 100%;scroll-snap-align:start;min-width:0}
  .svc-dots{display:flex;justify-content:center;gap:8px;margin-top:8px}
  .svc-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,82,204,.2);transition:background .25s}
  .svc-dot.active{background:#0052CC}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .hero{flex-direction:column;align-items:stretch;min-height:auto;padding-top:var(--hh);padding-left:0;padding-right:0;padding-bottom:0}
  .hero-bg{position:relative;width:100%;height:432px}
  .hero-bg::after{display:none}
  .hero-cnt{position:absolute;top:calc(50% + var(--hh)/2);transform:translateY(-50%);left:0;right:0;padding:0 20px;text-align:center;background:transparent}
  .hero h1{color:#fff;font-size:2.2rem}
  .hero-copy{color:rgba(255,255,255,.88);margin:0 auto}
  .hero-tel-btn{display:inline-flex;align-items:center;gap:8px;margin-top:22px;padding:13px 28px;background:#fff;color:#0052CC;font-size:1rem;font-weight:700;border-radius:50px;text-decoration:none;box-shadow:0 4px 18px rgba(0,0,0,.22);letter-spacing:.02em}
  .hero-contact-btn{display:none}
  .cta-txt-mob{display:inline}
  .cta-txt-pc{display:none}
  .full-img{display:none}
  .pain{display:none}
  .ba-sec{padding:45px 20px}
  .intro-sec{padding:36px 20px}
  .intro-card-top{padding:24px 20px 0}
  .intro-benefit{padding:14px 20px}
  .intro-card-top .rotator{height:4rem}
  .ba-wrap{aspect-ratio:4/3}
  .cta-mob{display:flex;flex-direction:column;align-items:center;gap:12px}
  .cta-pc{display:none}
  .ft-in{flex-direction:column;gap:22px}.ft-nav{flex-wrap:wrap;gap:14px}
  .case-hero-img{height:280px}
  .case-imgs{grid-template-columns:1fr}
  .case-nav{flex-direction:column}
  .contact-btns{flex-direction:column}
}

/* ── 지역별 서비스 (area-service template) ──────────────── */
.area-breadcrumb{background:#f5f5f5;padding:10px 24px}
.area-breadcrumb ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:4px;font-size:.82rem;color:#888;max-width:900px;margin:0 auto}
.area-breadcrumb li+li::before{content:"›";margin-right:4px}
.area-breadcrumb a{color:#555;text-decoration:none}
.area-breadcrumb a:hover{color:#0052CC}
.area-breadcrumb [aria-current]{color:#333}

.area-hero{position:relative;height:54vw;max-height:500px;min-height:280px;background-size:cover;background-position:center;background-color:#2a2a2a}
.area-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.12) 0%,rgba(0,0,0,.58) 100%)}
.area-hero-cnt{position:absolute;bottom:18%;left:48px;right:auto;max-width:600px}
.area-hero-h1{font-size:1.85rem;font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.65);margin:0 0 8px;line-height:1.3}
.area-hero-sub{color:rgba(255,255,255,.9);font-size:1rem;text-shadow:0 1px 6px rgba(0,0,0,.5);margin:0 0 22px}
.area-hero-btn{display:inline-flex;align-items:center;gap:7px;padding:13px 26px;border-radius:6px;font-size:.97rem;font-weight:600;text-decoration:none;transition:opacity .2s}
.area-hero-btn:hover{opacity:.86}
.area-btn-tel{background:#0c6fc7;color:#fff}
.area-btn-contact{background:#fff;color:#0052CC;border:2px solid rgba(255,255,255,.8)}
.area-btn-mobile{display:none}
.area-btn-pc{display:inline-flex}

.area-body{max-width:800px;margin:0 auto;padding:52px 28px 48px}
.area-body-inner p{line-height:1.88;color:#2c2c2c;margin:0 0 22px;font-size:.975rem}
.area-body-inner h2{font-size:1.2rem;font-weight:700;color:#111;margin:0 0 16px;padding-top:8px}

.area-cta-sec{background:#eef4ff;padding:44px 24px;text-align:center}
.area-cta-inner{max-width:480px;margin:0 auto}
.area-cta-ttl{font-size:1.25rem;font-weight:700;color:#111;margin:0 0 6px}
.area-cta-sub{font-size:.88rem;color:#555;margin:0 0 22px}
.area-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.area-cta-btn-contact{display:inline-flex;align-items:center;padding:14px 34px;background:#0052CC;color:#fff;border-radius:6px;font-size:1rem;font-weight:700;text-decoration:none;transition:opacity .2s}
.area-cta-btn-contact:hover{opacity:.88}
.area-cta-btn-tel{display:inline-flex;align-items:center;padding:14px 34px;background:#fff;color:#0052CC;border:2px solid #0052CC;border-radius:6px;font-size:1rem;font-weight:700;text-decoration:none;transition:opacity .2s}
.area-cta-btn-tel:hover{opacity:.85}

@media(max-width:767px){
  .area-hero-cnt{left:20px;right:20px;bottom:10%;max-width:100%}
  .area-hero-h1{font-size:1.3rem}
  .area-hero-sub{font-size:.875rem;margin-bottom:18px}
  .area-btn-mobile{display:inline-flex}
  .area-btn-pc{display:none}
  .area-body{padding:36px 20px 32px}
  .area-cta-sec{padding:36px 20px}
  .area-cta-btns{flex-direction:column;align-items:center}
  .area-cta-btn-contact,.area-cta-btn-tel{width:100%;max-width:280px;justify-content:center}
  .area-breadcrumb{padding:8px 16px}
}

/* ── 랜딩페이지 섹션 (ld-*) v2.8.0 ──────────────────── */
.ld-inner{max-width:860px;margin:0 auto;padding:0 28px}
.ld-title{font-size:1.4rem;font-weight:700;color:#111;margin:0 0 10px;text-align:center;line-height:1.4}
.ld-sub{text-align:center;color:#555;font-size:.92rem;margin:0 0 32px;line-height:1.7}
.ld-intro{text-align:center;color:#555;font-size:.92rem;margin:0 0 28px;line-height:1.75}
.ld-intro strong{color:#0052CC;font-weight:700}

/* Cause cards */
.ld-causes-sec{padding:56px 0;background:#f8f9fb}
.ld-cause-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ld-cause-card{background:#fff;border-radius:12px;padding:22px 18px;border:2px solid #eee}
.ld-cause-card.is-focus{border-color:#0052CC;background:#f5f8ff}
.ld-num{display:inline-block;font-size:.78rem;font-weight:700;color:#0052CC;background:#e8f0fe;padding:3px 10px;border-radius:20px;margin-bottom:10px;letter-spacing:.03em}
.ld-cause-card.is-focus .ld-num{background:#0052CC;color:#fff}
.ld-cause-card strong{display:block;font-size:.95rem;font-weight:700;color:#111;margin-bottom:8px}
.ld-cause-card p{font-size:.87rem;color:#555;line-height:1.75;margin:0}

/* Before/After */
.ld-ba-sec{padding:56px 0;background:#fff}
.ld-ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ld-ba-fig{margin:0;position:relative;border-radius:10px;overflow:hidden;background:#f0f0f0}
.ld-ba-fig img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.ld-ba-label{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.58);color:#fff;font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:4px;letter-spacing:.04em}
.ld-ba-after{background:rgba(0,82,204,.75)}

/* Why us */
.ld-why-sec{padding:56px 0;background:#eef4ff}
.ld-why-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ld-why-card{background:#fff;border-radius:12px;padding:22px 18px;display:flex;align-items:flex-start;gap:14px}
.ld-why-icon{width:34px;height:34px;border-radius:50%;background:#0052CC;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.92rem;font-weight:700;flex-shrink:0;margin-top:2px}
.ld-why-card>div>strong{display:block;font-size:.95rem;font-weight:700;color:#111;margin-bottom:6px}
.ld-why-card>div>p{font-size:.86rem;color:#555;margin:0;line-height:1.7}

/* Process */
.ld-proc-sec{padding:56px 0;background:#fff}
.ld-proc-steps{display:flex;align-items:flex-start;gap:4px}
.ld-proc-step{flex:1;text-align:center;padding:0 6px}
.ld-proc-arrow{color:#ccc;font-size:1.2rem;margin-top:10px;flex-shrink:0;line-height:42px}
.ld-proc-num{width:42px;height:42px;border-radius:50%;background:#0052CC;color:#fff;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.ld-proc-step strong{display:block;font-size:.9rem;font-weight:700;color:#111;margin-bottom:5px}
.ld-proc-step p{font-size:.8rem;color:#666;line-height:1.6;margin:0}

@media(max-width:767px){
  .ld-causes-sec,.ld-ba-sec,.ld-why-sec,.ld-proc-sec{padding:40px 0}
  .ld-inner{padding:0 16px}
  .ld-title{font-size:1.15rem}
  .ld-cause-grid,.ld-why-grid{grid-template-columns:1fr}
  .ld-ba-grid{grid-template-columns:1fr 1fr}
  .ld-proc-steps{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .ld-proc-arrow{display:none}
  .ld-proc-step{width:100%;max-width:none;background:#eef4ff;border-radius:12px;padding:18px 14px}
}
