/* ============================================================
   WL — style.css  |  Romantic Lavender Design System
   ============================================================ */

/* 1. Design Tokens */
:root {
  --pearl:   #FCFAFA;
  --lav-50:  #F6F3F8;
  --lav-100: #EBE5F0;
  --lav-200: #D5C6E1;
  --lav-300: #BCA4CE;
  --lav-400: #9E80B4;
  --lav-800: #4A3B52;
  --lav-900: #2D2333;
  --gold:    #C5A880;

  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Jost', sans-serif;
  --body:  'Noto Sans KR', 'Jost', sans-serif;

  --track-wide:  .1em;
  --track-wider: .2em;
  --track-super: .3em;

  --ease: cubic-bezier(.4,0,.2,1);
  --transition: all .35s var(--ease);
  --shadow: 0 8px 40px rgba(45,35,51,.1);
  --shadow-lav: 0 16px 60px rgba(188,164,206,.25);
}

/* 2. Reset & Base */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  font-size:16px;line-height:1.8;
  color:var(--lav-800);background:var(--pearl);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
::selection{background:var(--lav-200);color:var(--lav-900)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
strong{font-weight:600}

/* 3. Layout */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
@media(max-width:768px){.container{padding:0 24px}}

.sec{padding:120px 0}
@media(max-width:768px){.sec{padding:72px 0}}

.sec-title{
  font-family:var(--body);
  font-size:clamp(26px,4vw,38px);font-weight:700;
  color:var(--lav-900);letter-spacing:-.02em;margin-bottom:12px;
}
.sec-title-serif{
  font-family:var(--serif);
  font-size:clamp(30px,5vw,48px);font-weight:500;
  color:var(--lav-900);letter-spacing:.02em;margin-bottom:8px;
}
.sec-sub{
  font-size:14px;color:var(--lav-400);
  font-family:var(--sans);font-weight:300;margin-bottom:64px;
}
.sec-sub-label{
  display:block;font-family:var(--sans);
  font-size:10px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-super);
  color:var(--lav-400);margin-bottom:80px;
}
@media(max-width:768px){.sec-sub-label{margin-bottom:48px}}

.gold-line{width:48px;height:1px;background:var(--gold);margin:0 0 28px}

/* 4. Buttons */
.btn-primary{
  display:inline-block;padding:16px 40px;
  background:var(--lav-900);color:var(--pearl);
  font-family:var(--sans);font-size:11px;font-weight:400;
  letter-spacing:var(--track-super);text-transform:uppercase;
  border-radius:9999px;
  transition:var(--transition);
}
.btn-primary:hover{background:var(--lav-300)}

.btn-outline{
  display:inline-block;padding:13px 32px;
  border:1px solid var(--lav-900);color:var(--lav-900);
  font-family:var(--sans);font-size:11px;font-weight:400;
  letter-spacing:var(--track-wider);text-transform:uppercase;
  border-radius:9999px;
  transition:var(--transition);
}
.btn-outline:hover{background:var(--lav-900);color:var(--pearl)}

.arrow-link{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-super);
  color:var(--lav-900);transition:color .3s;
}
.arrow-link .a-line{
  display:block;width:32px;height:1px;
  background:var(--lav-400);transition:width .3s ease;
}
.arrow-link:hover{color:var(--lav-400)}
.arrow-link:hover .a-line{width:48px}

/* ============================================================
   5. Header
   ============================================================ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:24px 48px;
  display:flex;align-items:center;justify-content:space-between;
  transition:var(--transition);
}
.hdr.scrolled{
  background:rgba(252,250,250,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--lav-100);
  padding:14px 48px;
}
@media(max-width:768px){
  .hdr{padding:18px 24px}
  .hdr.scrolled{padding:12px 24px}
}
.hdr-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--serif);font-size:18px;font-weight:500;
  letter-spacing:.04em;transition:color .35s;
}
.hdr:not(.scrolled) .hdr-logo{color:var(--pearl)}
.hdr.scrolled .hdr-logo{color:var(--lav-900)}
.hdr-logo svg{width:30px;height:30px}

.logo-img{height:30px;width:auto;display:block;flex-shrink:0;filter:brightness(0) invert(1);opacity:.85;transition:filter .35s ease,opacity .35s ease}
.hdr.scrolled .logo-img{filter:none;opacity:1}

.logo-text{font-family:var(--serif);font-size:18px;font-weight:500;letter-spacing:.04em}

.hdr-nav{display:flex;align-items:center;gap:36px}
.hdr-nav a{
  font-family:var(--sans);font-size:10px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  transition:color .3s;
}
.hdr:not(.scrolled) .hdr-nav a{color:rgba(255,255,255,.8)}
.hdr.scrolled .hdr-nav a{color:var(--lav-800)}
.hdr-nav a:hover{color:var(--lav-300)!important}

.hdr-cta{
  padding:10px 22px;
  font-family:var(--sans);font-size:10px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  transition:var(--transition);
}
.hdr:not(.scrolled) .hdr-cta{border:1px solid rgba(255,255,255,.7);color:var(--pearl)!important;background:rgba(45,35,51,.18)}
.hdr:not(.scrolled) .hdr-cta:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.9)}
.hdr.scrolled .hdr-cta{background:var(--lav-900);color:var(--pearl)!important;border:1px solid var(--lav-900)}
.hdr.scrolled .hdr-cta:hover{background:var(--lav-300);border-color:var(--lav-300)}

.ham{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;
}
.ham span{display:block;width:22px;height:1px;background:currentColor;transition:.3s}
.hdr:not(.scrolled) .ham{color:var(--pearl)}
.hdr.scrolled .ham{color:var(--lav-900)}
@media(max-width:768px){.hdr-nav.desktop{display:none}.ham{display:flex}}

.mob-menu{
  display:none;position:fixed;inset:0;
  background:var(--pearl);z-index:850;
  padding:80px 32px 40px;flex-direction:column;gap:0;
}
.mob-menu.open{display:flex}
.mob-menu a{
  font-family:var(--body);font-size:18px;font-weight:400;
  color:var(--lav-800);
  border-bottom:1px solid var(--lav-100);padding:20px 0;
}
.mob-menu a:last-child{color:var(--lav-300);font-weight:600;border-bottom:none;margin-top:12px}

/* ============================================================
   6. Hero — Split Layout
   ============================================================ */
.hero{
  min-height:100vh;padding:120px 0 80px;
  background:var(--lav-900);
  display:flex;align-items:center;
  position:relative;overflow:hidden;
}
@media(max-width:768px){.hero{padding:96px 0 64px;min-height:auto}}

.hero-inner{
  display:grid;grid-template-columns:5fr 7fr;
  gap:64px;align-items:center;
}
@media(max-width:1024px){.hero-inner{grid-template-columns:1fr 1fr;gap:48px}}
@media(max-width:768px){.hero-inner{grid-template-columns:1fr;gap:40px}}

.hero-text{z-index:2;order:1}

.hero-badge{
  display:inline-block;
  font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-super);
  color:var(--lav-400);
  border-bottom:1px solid var(--lav-800);
  padding-bottom:8px;margin-bottom:28px;
}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(44px,6.5vw,80px);
  font-weight:500;line-height:1.08;
  color:var(--pearl);margin-bottom:16px;letter-spacing:.01em;
}
.hero-deco{
  font-family:var(--serif);
  font-size:clamp(14px,1.4vw,18px);
  font-weight:400;line-height:1.6;
  color:rgba(252,250,250,.55);margin-bottom:28px;letter-spacing:.04em;
}
.hero-deco em{font-style:italic;color:var(--lav-300)}
.hero-sub{
  font-family:var(--body);font-size:14px;font-weight:300;
  color:rgba(252,250,250,.65);line-height:1.9;
  margin-bottom:12px;max-width:340px;
}
.hero-notice{
  font-size:12px;color:rgba(252,250,250,.38);
  line-height:1.7;margin-bottom:40px;max-width:320px;
}
.hero .arrow-link{color:var(--pearl)}
.hero .arrow-link .a-line{background:rgba(252,250,250,.45)}
.hero .arrow-link:hover{color:var(--lav-300)}
.hero .arrow-link:hover .a-line{background:var(--lav-300)}

@media(max-width:768px){
  .hero-badge{margin-bottom:16px}
  .hero-h1{margin-bottom:10px}
  .hero-deco{margin-bottom:16px}
  .hero-notice{margin-bottom:24px}
}

.hero-img-side{z-index:1;order:2}

.hero-arch-wrap{
  position:relative;width:100%;max-width:520px;
  margin-left:auto;aspect-ratio:3/4;
  border-radius:9999px 9999px 0 0;
  overflow:hidden;box-shadow:var(--shadow-lav);
}
@media(max-width:768px){.hero-arch-wrap{max-width:100%;aspect-ratio:4/3}}
.hero-arch-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.5s cubic-bezier(.25,1,.5,1);
}
.hero-arch-wrap:hover img{transform:scale(1.04)}
.hero-arch-overlay{
  position:absolute;inset:0;
  background:rgba(45,35,51,.12);mix-blend-mode:overlay;
}

/* ============================================================
   7. Quote Section
   ============================================================ */
.quote-sec{padding:120px 0;background:var(--lav-50)}
@media(max-width:768px){.quote-sec{padding:80px 0}}

.quote-inner{max-width:800px;margin:0 auto;text-align:center;padding:0 24px}
.quote-icon{width:28px;height:28px;color:var(--lav-300);margin:0 auto 28px}
.quote-text{
  font-family:var(--serif);
  font-size:clamp(20px,3vw,34px);font-weight:400;
  color:var(--lav-900);line-height:1.65;
  letter-spacing:.01em;margin-bottom:28px;quotes:none;
}
.quote-attr{
  font-family:var(--sans);font-size:10px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);color:var(--lav-400);
}

/* ============================================================
   8. Service Section — Alternating
   ============================================================ */
.service-sec{padding:120px 0;background:var(--pearl)}
@media(max-width:768px){.service-sec{padding:80px 0}}

.service-header{text-align:center;margin-bottom:80px}
@media(max-width:768px){.service-header{margin-bottom:56px}}

.service-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;margin-bottom:120px;
}
.service-row:last-child{margin-bottom:0}
@media(max-width:1024px){.service-row{gap:48px}}
@media(max-width:768px){.service-row{grid-template-columns:1fr;gap:36px;margin-bottom:72px}}

.service-row.reverse .service-img-side{order:2}
.service-row.reverse .service-text-side{order:1}
@media(max-width:768px){
  .service-row.reverse .service-img-side{order:1}
  .service-row.reverse .service-text-side{order:2}
}

.service-arch-wrap{
  position:relative;aspect-ratio:4/5;
  border-radius:9999px 9999px 0 0;overflow:hidden;
}
@media(max-width:768px){.service-arch-wrap{aspect-ratio:4/3}}
.service-arch-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.5s cubic-bezier(.25,1,.5,1);
}
.service-arch-wrap:hover img{transform:scale(1.05)}
.service-arch-wrap::after{
  content:'';position:absolute;inset:20px;
  border:1px solid rgba(252,250,250,.5);
  pointer-events:none;z-index:1;
  border-radius:9999px 9999px 0 0;
}

.service-text-side{position:relative;padding:8px 0}
.service-watermark{
  font-family:var(--serif);
  font-size:clamp(72px,11vw,120px);font-weight:400;
  color:var(--lav-100);
  position:absolute;top:-32px;left:-12px;
  line-height:1;pointer-events:none;user-select:none;z-index:0;
}
.service-heading{
  font-family:var(--body);
  font-size:clamp(22px,3vw,32px);font-weight:700;
  color:var(--lav-900);margin-bottom:20px;
  position:relative;z-index:1;letter-spacing:-.01em;
}
.service-desc{
  font-size:15px;font-weight:300;color:var(--lav-800);
  line-height:1.9;margin-bottom:28px;position:relative;z-index:1;
}
.service-features{list-style:none;margin-bottom:36px;position:relative;z-index:1}
.service-features li{
  display:flex;align-items:center;gap:12px;
  font-size:14px;color:var(--lav-800);margin-bottom:10px;font-weight:300;
}
.service-features li::before{
  content:'';flex-shrink:0;
  width:6px;height:6px;border-radius:50%;background:var(--lav-300);
}

/* ============================================================
   9. Cases Section
   ============================================================ */
.cases-sec{padding:120px 0;background:var(--lav-50)}
@media(max-width:768px){.cases-sec{padding:80px 0}}

.cases-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-bottom:56px;
}
@media(max-width:1024px){.cases-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cases-grid{grid-template-columns:1fr;gap:16px}}

.case-card{background:var(--pearl);overflow:hidden;transition:box-shadow .4s}
.case-card:hover{box-shadow:var(--shadow)}

.case-imgs{display:grid;grid-template-columns:1fr 1fr}
.case-img-wrap{position:relative;aspect-ratio:1;overflow:hidden}
.case-img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.25,1,.5,1);
}
.case-card:hover .case-img-wrap img{transform:scale(1.05)}

.case-label{
  position:absolute;top:10px;left:10px;
  font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--pearl);background:rgba(45,35,51,.55);
  padding:4px 8px;z-index:2;
}
.case-label.after{background:rgba(188,164,206,.75)}

.case-info{padding:20px 22px 24px}
.case-cat{
  font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);margin-bottom:6px;
}
.case-title{font-family:var(--body);font-size:15px;font-weight:600;color:var(--lav-900);margin-bottom:6px}
.case-meta{font-size:12px;color:var(--lav-400);font-weight:300;margin-bottom:14px}
.case-btn{font-size:9px;padding:7px 18px;letter-spacing:var(--track-wider)}
.sec-more{text-align:center;margin-top:48px}

/* ============================================================
   10. Stats Section
   ============================================================ */
.stats-sec{padding:100px 0;background:var(--lav-900)}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:48px;text-align:center;
}
@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:40px}}

.stat-item{padding:8px}
.stat-num-wrap{
  display:flex;align-items:baseline;justify-content:center;
  gap:2px;margin-bottom:12px;
}
.stat-num{
  font-family:var(--serif);
  font-size:clamp(40px,6vw,64px);font-weight:400;
  color:var(--pearl);line-height:1;
}
.stat-unit{
  font-family:var(--serif);
  font-size:clamp(18px,3vw,26px);font-weight:400;color:var(--lav-300);
}
.stat-label{
  font-family:var(--sans);font-size:10px;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);font-weight:300;
}

/* ============================================================
   11. FAQ Section
   ============================================================ */
.faq-sec{padding:120px 0;background:var(--pearl)}
@media(max-width:768px){.faq-sec{padding:80px 0}}
.faq-inner{max-width:760px;margin:0 auto}

.faq-list{margin-top:0}
.faq-item{border-bottom:1px solid var(--lav-100)}
.faq-q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:26px 0;
  display:flex;justify-content:space-between;align-items:flex-start;gap:20px;
  font-family:var(--body);font-size:15px;font-weight:500;
  color:var(--lav-900);line-height:1.6;transition:color .3s;
}
.faq-q:hover{color:var(--lav-300)}
.faq-icon{flex-shrink:0;width:18px;height:18px;position:relative;margin-top:4px}
.faq-icon::before,.faq-icon::after{
  content:'';position:absolute;background:currentColor;
  transition:transform .3s,opacity .3s;
}
.faq-icon::before{width:12px;height:1px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-icon::after{width:1px;height:12px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}

.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:500px}
.faq-a p{padding:0 0 26px;font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.9}

/* ============================================================
   12. Region Section
   ============================================================ */
.region-sec{padding:100px 0;background:var(--lav-50)}
@media(max-width:768px){.region-sec{padding:64px 0}}

.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
@media(max-width:768px){.region-grid{grid-template-columns:repeat(2,1fr)}}

.region-card{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:12px;
  padding:40px 16px;background:var(--pearl);transition:var(--transition);
}
.region-card:hover{background:var(--lav-900)}
.region-card-icon{
  width:28px;height:28px;
  border:1px solid var(--lav-200);border-radius:50%;transition:var(--transition);
}
.region-card:hover .region-card-icon{border-color:var(--lav-300);background:var(--lav-300)}
.region-card-title{
  font-family:var(--body);font-size:13px;font-weight:500;
  color:var(--lav-800);text-align:center;transition:color .3s;
}
.region-card:hover .region-card-title{color:var(--pearl)}

/* ============================================================
   13. CTA Section
   ============================================================ */
.cta-sec{padding:120px 0;background:var(--lav-900);text-align:center}
@media(max-width:768px){.cta-sec{padding:80px 0}}

.cta-label{
  display:block;font-family:var(--sans);font-size:9px;
  text-transform:uppercase;letter-spacing:var(--track-super);
  color:var(--lav-400);margin-bottom:20px;
}
.cta-title{
  font-family:var(--serif);font-size:clamp(28px,5vw,52px);
  font-weight:500;color:var(--pearl);margin-bottom:16px;
  line-height:1.25;letter-spacing:.02em;
}
.cta-title em{font-style:italic;color:var(--lav-300)}
.cta-sub{
  font-size:14px;font-weight:300;
  color:rgba(252,250,250,.55);margin-bottom:48px;line-height:1.9;
}

/* ============================================================
   14. Footer
   ============================================================ */
.ftr{background:var(--lav-900);color:var(--pearl);border-top:1px solid rgba(255,255,255,.04)}

.ftr-top{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:88px 48px 60px;max-width:1280px;margin:0 auto;
  border-bottom:1px solid rgba(255,255,255,.07);
  gap:48px;flex-wrap:wrap;
}
@media(max-width:768px){.ftr-top{padding:56px 24px 40px;flex-direction:column;align-items:flex-start}}

.ftr-brand-heading{
  font-family:var(--serif);
  font-size:clamp(28px,5vw,44px);font-weight:500;
  color:var(--pearl);line-height:1.2;margin-bottom:16px;letter-spacing:.02em;
}
.ftr-brand-heading em{font-style:italic;color:var(--lav-300)}
.ftr-brand-desc{
  font-family:var(--sans);font-size:13px;font-weight:300;
  color:rgba(252,250,250,.55);line-height:1.9;
  margin-bottom:32px;max-width:380px;
}
.ftr-info-col{display:flex;flex-direction:column;gap:20px;min-width:200px}
.ftr-info-label{
  display:block;font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);margin-bottom:6px;
}
.ftr-info-col p{
  font-family:var(--sans);font-size:13px;font-weight:300;
  color:rgba(252,250,250,.6);line-height:1.7;
}

.ftr-links-row{
  display:flex;gap:24px;flex-wrap:wrap;
  padding:16px 48px;max-width:1280px;margin:0 auto;
  border-bottom:1px solid rgba(255,255,255,.05);
}
@media(max-width:768px){.ftr-links-row{padding:16px 24px;gap:16px}}
.ftr-links-row a{
  font-family:var(--sans);font-size:11px;font-weight:300;
  color:rgba(252,250,250,.38);transition:color .3s;
}
.ftr-links-row a:hover{color:var(--pearl)}

.ftr-bottom{
  padding:20px 48px;max-width:1280px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;flex-wrap:wrap;
}
@media(max-width:768px){.ftr-bottom{padding:20px 24px;flex-direction:column;gap:8px}}

.ftr-biz{
  font-family:var(--sans);font-size:10px;font-weight:300;
  color:rgba(252,250,250,.24);line-height:1.9;
}
.ftr-biz p+p{margin-top:2px}
.ftr-copy{
  font-family:var(--sans);font-size:10px;font-weight:300;
  color:rgba(252,250,250,.24);
  text-transform:uppercase;letter-spacing:var(--track-wide);white-space:nowrap;
}

/* ============================================================
   15. Floating CTA & Back to Top
   ============================================================ */
.float-cta{
  position:fixed;bottom:32px;right:32px;
  width:60px;height:60px;
  background:var(--lav-300);border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:800;box-shadow:0 4px 24px rgba(188,164,206,.45);
}
.float-cta-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:1px solid var(--lav-300);
  animation:ring-pulse 2.5s infinite;
}
@keyframes ring-pulse{
  0%,100%{transform:scale(1);opacity:.8}
  50%{transform:scale(1.18);opacity:0}
}
.float-cta-text{
  font-family:var(--body);font-size:11px;font-weight:700;
  color:var(--pearl);text-align:center;line-height:1.2;
}
.back-top{
  position:fixed;bottom:104px;right:32px;
  width:38px;height:38px;background:var(--pearl);
  border:1px solid var(--lav-200);color:var(--lav-800);
  font-size:18px;cursor:pointer;
  display:none;align-items:center;justify-content:center;
  z-index:800;transition:var(--transition);
}
.back-top.show{display:flex}
.back-top:hover{background:var(--lav-900);color:var(--pearl);border-color:var(--lav-900)}

/* ============================================================
   16. Subhero
   ============================================================ */
.subhero{position:relative;height:480px;overflow:hidden}
@media(max-width:768px){.subhero{height:300px}}
.subhero img{width:100%;height:100%;object-fit:cover}
.subhero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(45,35,51,.72) 0%,rgba(45,35,51,.25) 100%);
  display:flex;align-items:flex-end;
}
.subhero-overlay .container{padding-bottom:56px}
@media(max-width:768px){.subhero-overlay .container{padding-bottom:36px}}
.subhero-cat{
  display:block;font-family:var(--sans);font-size:9px;
  text-transform:uppercase;letter-spacing:var(--track-super);
  color:var(--lav-300);margin-bottom:10px;
}
.subhero-h1{
  font-family:var(--body);font-size:clamp(26px,5vw,46px);
  font-weight:700;color:var(--pearl);letter-spacing:-.01em;
}

/* Small hero (gallery page) */
.subhero-sm{padding:140px 0 56px;background:var(--lav-900)}
.subhero-sm h1{
  font-family:var(--serif);
  font-size:clamp(32px,6vw,56px);font-weight:400;
  color:var(--pearl);letter-spacing:.02em;margin-bottom:12px;
}
.subhero-sm p{font-size:13px;font-weight:300;color:rgba(252,250,250,.55);font-family:var(--sans)}

.page-body{padding:80px 48px 120px}
@media(max-width:768px){.page-body{padding:48px 24px 80px}}

/* ============================================================
   17. Content (service & local pages)
   ============================================================ */
.content-sec{margin-bottom:64px}
.content-sec-sub{
  font-size:14px;font-weight:300;color:var(--lav-400);
  margin-bottom:32px;line-height:1.8;
}
.content-sec h2{
  font-family:var(--body);font-size:clamp(20px,3vw,28px);
  font-weight:700;color:var(--lav-900);margin-bottom:20px;letter-spacing:-.01em;
}
.content-quote{
  font-family:var(--serif);
  font-size:clamp(16px,2vw,20px);font-weight:400;
  color:var(--lav-800);line-height:1.75;
  border-left:3px solid var(--lav-300);
  padding:20px 28px;margin:32px 0;background:var(--lav-50);
  quotes:none;
}
@media(max-width:768px){.content-quote{padding:16px 20px}}

.diff-list{list-style:none;counter-reset:none;margin-bottom:0}
.diff-list li{
  display:flex;align-items:flex-start;gap:20px;
  padding:22px 0;border-bottom:1px solid var(--lav-100);
}
.diff-list li:last-child{border-bottom:none}
.diff-n{
  font-family:var(--serif);font-size:28px;font-weight:400;
  color:var(--lav-200);line-height:1;flex-shrink:0;width:40px;padding-top:2px;
}
.diff-list li p{
  font-size:15px;font-weight:300;color:var(--lav-800);
  line-height:1.85;margin:0;flex:1;
}
.content-sec h3{font-family:var(--body);font-size:17px;font-weight:600;color:var(--lav-900);margin-bottom:12px}
.content-sec p{font-size:15px;font-weight:300;color:var(--lav-800);line-height:1.9;margin-bottom:14px}

.content-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.content-list li{
  display:flex;gap:12px;align-items:flex-start;
  font-size:15px;font-weight:300;color:var(--lav-800);line-height:1.75;
}
.content-list li::before{
  content:'';flex-shrink:0;
  width:6px;height:6px;border-radius:50%;background:var(--lav-300);margin-top:8px;
}

.content-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
@media(max-width:768px){.content-cards{grid-template-columns:1fr;gap:12px}}
.content-card{background:var(--lav-50);padding:28px 24px;border-top:2px solid var(--lav-300)}
.content-card h3{font-size:16px;font-weight:600;color:var(--lav-900);margin-bottom:10px}
.content-card p{font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.8;margin:0}

.step-list{list-style:none;margin-bottom:40px}
.step-list li{
  display:flex;gap:20px;align-items:flex-start;
  padding:24px 0;border-bottom:1px solid var(--lav-100);
}
.step-n{
  font-family:var(--serif);font-size:28px;font-weight:400;
  color:var(--lav-200);line-height:1;flex-shrink:0;width:36px;
}
.step-list li div{flex:1}
.step-list li div strong{display:block;font-size:15px;font-weight:600;color:var(--lav-900);margin-bottom:6px}
.step-list li div p{font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.8;margin:0}

.related-grid{display:flex;gap:12px;flex-wrap:wrap}
.related-card{
  display:inline-block;padding:12px 20px;
  border:1px solid var(--lav-200);
  font-size:13px;font-weight:400;color:var(--lav-800);transition:var(--transition);
}
.related-card:hover{background:var(--lav-900);color:var(--pearl);border-color:var(--lav-900)}

/* Local page */
.local-highlight{
  background:var(--lav-50);border-left:3px solid var(--lav-300);
  padding:28px 36px;margin-bottom:36px;
}
.local-highlight h2{margin-bottom:10px}
.local-highlight p{font-size:14px;color:var(--lav-800);margin:0}

.local-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.local-info-grid{grid-template-columns:1fr}}
.local-info-card{background:var(--pearl);border:1px solid var(--lav-100);padding:24px}
.local-info-card h3{
  font-size:10px;font-family:var(--sans);text-transform:uppercase;
  letter-spacing:var(--track-wider);color:var(--lav-400);
  margin-bottom:14px;font-weight:400;
}
.local-tags{display:flex;flex-wrap:wrap;gap:8px}
.local-tag{
  display:inline-block;padding:6px 12px;
  background:var(--lav-50);border:1px solid var(--lav-100);
  font-size:13px;font-weight:300;color:var(--lav-800);
}

.page-cta{text-align:center;padding:56px 0;border-top:1px solid var(--lav-100);margin-top:40px}
.page-cta p{font-size:17px;font-weight:500;color:var(--lav-900);margin-bottom:24px}
.empty-msg{text-align:center;padding:80px 24px;font-size:15px;color:var(--lav-400)}

/* ============================================================
   18. Portfolio Detail
   ============================================================ */
.pd-hero{position:relative;height:500px;overflow:hidden}
@media(max-width:768px){.pd-hero{height:320px}}
.pd-hero img{width:100%;height:100%;object-fit:cover}
.pd-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(45,35,51,.82) 0%,rgba(45,35,51,.18) 60%);
  display:flex;align-items:flex-end;
}
.pd-hero-overlay .container{padding-bottom:48px}
.pd-hero-overlay h1{
  font-family:var(--body);
  font-size:clamp(24px,4vw,40px);font-weight:700;
  color:var(--pearl);letter-spacing:-.01em;
}

.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:48px}
.ba-item{position:relative;aspect-ratio:3/4;overflow:hidden}
.ba-item img{width:100%;height:100%;object-fit:cover}
.ba-item .case-label{bottom:14px;left:14px;top:auto}

.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-bottom:48px}
@media(max-width:768px){.summary-cards{grid-template-columns:repeat(2,1fr)}}
.summary-card{background:var(--lav-50);padding:22px 18px}
.summary-label{
  display:block;font-family:var(--sans);font-size:9px;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);margin-bottom:8px;font-weight:400;
}
.summary-val{font-size:14px;font-weight:600;color:var(--lav-900)}

.pd-nav{
  display:flex;justify-content:space-between;gap:16px;
  padding-top:40px;border-top:1px solid var(--lav-100);flex-wrap:wrap;
}
.pd-nav-prev,.pd-nav-next{
  font-family:var(--sans);font-size:11px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-800);transition:color .3s;
}
.pd-nav-prev:hover,.pd-nav-next:hover{color:var(--lav-300)}

/* ============================================================
   19. Sitemap Page
   ============================================================ */
.sitemap-body{padding:140px 0 56px;background:var(--lav-900)}
.sitemap-body h1{
  font-family:var(--serif);font-size:clamp(30px,5vw,48px);
  font-weight:400;color:var(--pearl);letter-spacing:.02em;
}
.sitemap-content{padding:56px 0 120px}
.sitemap-search{max-width:480px;margin:0 0 40px;display:flex}
.sitemap-search input{
  flex:1;padding:14px 18px;
  border:1px solid var(--lav-200);font-size:14px;
  font-family:var(--body);color:var(--lav-800);background:var(--pearl);outline:none;
}
.sitemap-search input:focus{border-color:var(--lav-300)}
.sitemap-search button{
  padding:0 24px;background:var(--lav-900);color:var(--pearl);
  border:none;cursor:pointer;font-family:var(--sans);
  font-size:11px;letter-spacing:var(--track-wider);text-transform:uppercase;
  transition:background .3s;
}
.sitemap-search button:hover{background:var(--lav-300)}
.sitemap-cat-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.sitemap-filter-btn{
  padding:8px 16px;border:1px solid var(--lav-200);
  background:var(--pearl);font-family:var(--sans);
  font-size:10px;text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-800);cursor:pointer;transition:var(--transition);
}
.sitemap-filter-btn.active,.sitemap-filter-btn:hover{
  background:var(--lav-900);color:var(--pearl);border-color:var(--lav-900);
}

/* ============================================================
   20. 404 Page
   ============================================================ */
.page-404{
  min-height:70vh;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:120px 24px;
}
.page-404 h1{
  font-family:var(--serif);
  font-size:clamp(72px,15vw,140px);font-weight:400;
  color:var(--lav-100);line-height:1;margin-bottom:24px;
}
.page-404 p{font-size:15px;color:var(--lav-400);margin-bottom:40px}
.page-404-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   21. Consultation Page
   ============================================================ */
.consultation-body{max-width:760px;margin:0 auto}

.consult-notice{
  background:var(--lav-50);border-left:3px solid var(--lav-300);
  padding:20px 24px;margin-bottom:56px;
  font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.8;
}
.consult-notice strong{font-weight:600;color:var(--lav-900)}

.consult-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
  margin-bottom:64px;
}
@media(max-width:600px){.consult-cards{grid-template-columns:1fr;gap:12px}}

.consult-card{
  background:var(--lav-50);padding:40px 32px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;
}
.consult-card.recommended{background:var(--lav-900)}
.consult-card.recommended .consult-card-title,
.consult-card.recommended .consult-card-desc,
.consult-card.recommended .consult-hours{color:var(--pearl)}
.consult-card.recommended svg path{stroke:var(--lav-300)}

.consult-card-icon{width:40px;height:40px;margin-bottom:8px}
.consult-badge{
  position:absolute;top:16px;right:16px;
  display:inline-block;padding:4px 12px;
  background:var(--lav-300);color:var(--pearl);
  font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
}
.consult-card-title{
  font-family:var(--serif);font-size:22px;font-weight:500;
  color:var(--lav-900);margin:0;
}
.consult-card-desc{
  font-size:14px;font-weight:300;color:var(--lav-800);
  line-height:1.8;margin:0;flex:1;
}
.consult-hours{
  font-family:var(--sans);font-size:12px;font-weight:300;
  color:var(--lav-400);margin:0;
}
.consult-card.recommended .consult-hours{color:rgba(252,250,250,.55)}
.consult-card.recommended .consult-btn{
  background:var(--lav-300);border-color:var(--lav-300);color:var(--pearl);
}
.consult-card.recommended .consult-btn:hover{background:var(--pearl);border-color:var(--pearl);color:var(--lav-900)}
.consult-btn{margin-top:8px;text-align:center}

.consult-guide{margin-bottom:56px}
.consult-guide h2{
  font-family:var(--body);font-size:18px;font-weight:700;
  color:var(--lav-900);margin-bottom:20px;
}

.consult-biz{
  background:var(--lav-50);padding:32px;margin-bottom:48px;
}
.consult-biz h2{
  font-family:var(--body);font-size:18px;font-weight:700;
  color:var(--lav-900);margin-bottom:20px;
}
.biz-dl{display:grid;grid-template-columns:max-content 1fr;gap:8px 24px}
.biz-dl dt{
  font-family:var(--sans);font-size:11px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);padding-top:2px;
}
.biz-dl dd{font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.7}

.consult-back{text-align:center;margin-top:16px}

/* ============================================================
   22. 404 Page (subhero-sm 기반)
   ============================================================ */
.err404-code{
  font-family:var(--serif);
  font-size:clamp(72px,15vw,140px);font-weight:400;
  color:rgba(252,250,250,.18);line-height:1;margin-bottom:16px;
}
.err404-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:32px}

/* ============================================================
   23. Sitemap Page
   ============================================================ */
.sitemap-ctrl{margin-bottom:40px}

.sitemap-search{
  width:100%;max-width:480px;padding:14px 18px;
  border:1px solid var(--lav-200);font-size:14px;
  font-family:var(--body);color:var(--lav-800);background:var(--pearl);
  outline:none;display:block;margin-bottom:20px;
}
.sitemap-search:focus{border-color:var(--lav-300)}

.sitemap-filters{display:flex;gap:8px;flex-wrap:wrap}
.sm-filter{
  padding:8px 18px;border:1px solid var(--lav-200);
  background:var(--pearl);font-family:var(--sans);
  font-size:10px;text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-800);cursor:pointer;transition:var(--transition);
}
.sm-filter.active,.sm-filter:hover{
  background:var(--lav-900);color:var(--pearl);border-color:var(--lav-900);
}

.sitemap-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);gap:2px;
  margin-top:40px;
}
@media(max-width:1024px){.sitemap-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.sitemap-grid{grid-template-columns:repeat(2,1fr)}}

.sitemap-card{
  background:var(--lav-50);padding:24px 20px;
  display:flex;flex-direction:column;gap:8px;
  transition:var(--transition);
}
.sitemap-card:hover{background:var(--lav-900)}
.sm-cat-badge{
  font-family:var(--sans);font-size:9px;font-weight:400;
  text-transform:uppercase;letter-spacing:var(--track-wider);
  color:var(--lav-400);transition:color .3s;
}
.sitemap-card:hover .sm-cat-badge{color:var(--lav-300)}
.sm-title{
  font-size:13px;font-weight:500;color:var(--lav-900);
  line-height:1.5;transition:color .3s;
}
.sitemap-card:hover .sm-title{color:var(--pearl)}

/* ============================================================
   24. Global utilities
   ============================================================ */
body{word-break:keep-all;overflow-wrap:break-word}

/* ============================================================
   25. Sub-page Entrance & Hover Animations
   ============================================================ */

/* Subhero — hero image Ken Burns zoom-out */
@keyframes wl-ken-burns{from{transform:scale(1.06)}to{transform:scale(1)}}
.subhero img{animation:wl-ken-burns 9s cubic-bezier(.25,1,.5,1) both}

/* Subhero — text slide-up entrance */
@keyframes wl-slide-up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.subhero-cat{animation:wl-slide-up .8s cubic-bezier(.4,0,.2,1) .35s both}
.subhero-h1{animation:wl-slide-up 1s cubic-bezier(.4,0,.2,1) .55s both}

/* Content card — lift on hover */
.content-card{transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.content-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lav)}

/* Step number — color pulse on row hover */
.step-n{transition:color .35s ease}
.step-list li:hover .step-n{color:var(--lav-300)}

/* Diff list number */
.diff-list li:hover .diff-n{color:var(--lav-300)}

/* Local tag — fill on hover */
.local-tag{transition:background .25s ease,border-color .25s ease}
.local-tag:hover{background:var(--lav-100);border-color:var(--lav-300)}

/* Related card — subtle lift */
.related-card{transition:transform .3s var(--ease),background .3s ease,color .3s ease}
.related-card:hover{transform:translateY(-3px)}

/* Local route info box */
.local-route-box{
  background:var(--lav-50);border-left:3px solid var(--lav-300);
  padding:20px 28px;margin:8px 0 0;
  font-size:14px;font-weight:300;color:var(--lav-800);line-height:1.9;
}
.local-route-sec .content-sec-sub{margin-bottom:0}

/* Mobile spacing overrides */
@media(max-width:768px){
  .content-sec{margin-bottom:40px}
  .local-route-box{padding:16px 20px}
  .page-cta{padding:40px 0}
}

/* Region more button */
.region-card--more{background:var(--lav-50);border:1px dashed var(--lav-300)}
.region-card--more .region-card-icon{color:var(--lav-400);font-style:normal;font-size:18px;transition:transform .3s var(--ease)}
.region-card--more:hover{background:var(--lav-900)}
.region-card--more:hover .region-card-icon{transform:translateX(4px);color:var(--pearl)}
