/*
Theme Name: Twenty Twenty-Five Child
Template: twentytwentyfive
Description: FINERO 피네로 벌목 전문
Version: 3.0.0
*/

/* ════════════════════════════════════
   Critical CSS — High-End Monochrome Editorial
   Base: #132A14 / Accent: #2E7D32
   (레퍼런스: scr.haengjipsaveteran.com 동일 디자인 시스템)
   ════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --dark:#132A14;
  --text-dark:#1C2E1D;
  --text-mid:#666666;
  --text-light:#999999;
  --bg:#F0EBE0;
  --bg2:#E5DFD3;
  --white:#FFFFFF;
  --border:#D4CEBC;
  --accent:#2E7D32;
  --bg1:#F0EBE0;
  --bg3:#E2E2E2;
}
body{
  font-family:'Noto Sans KR',system-ui,-apple-system,sans-serif;
  color:var(--text-dark);
  background:var(--bg);
  word-break:keep-all;overflow-wrap:break-word;
  font-weight:400;font-size:16px;line-height:1.8;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}
.font-display{font-family:'Sora','Noto Sans KR',sans-serif}
img{max-width:100%;height:auto}

/* ── Header ── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:#132A14;
  transition:background 500ms cubic-bezier(.16,1,.3,1),box-shadow 300ms;
}
.site-header.scrolled{
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(0,0,0,.08);
}
.header-inner{
  max-width:1440px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;height:72px;
}
@media(max-width:768px){.header-inner{padding:0 20px;height:64px}}

.header-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.header-logo-text{display:flex;flex-direction:column;line-height:1.2}
.header-logo-name{
  font-family:'Sora',sans-serif;font-weight:800;font-size:14px;
  letter-spacing:.1em;color:#fff;text-transform:uppercase;
  transition:color 400ms;
}
.site-header.scrolled .header-logo-name{color:#132A14}
.header-logo-kr{
  font-family:'Noto Sans KR',sans-serif;
  font-size:.85em;letter-spacing:.02em;font-weight:700;
}
.header-logo-sub{
  font-size:10px;letter-spacing:.04em;color:rgba(255,255,255,.45);
  font-weight:500;transition:color 400ms;font-family:'Noto Sans KR',sans-serif;
  text-transform:none;
}
.site-header.scrolled .header-logo-sub{color:#888}

.header-nav{display:flex;align-items:center;gap:36px}
.header-nav a{
  color:rgba(255,255,255,.55);text-decoration:none;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  transition:color 300ms;
}
.header-nav a:hover{color:#fff}
.site-header.scrolled .header-nav a{color:#888}
.site-header.scrolled .header-nav a:hover{color:#111}

.header-cta{
  display:inline-flex;align-items:center;
  background:#fff;color:#132A14;
  padding:10px 24px;
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;min-height:40px;
  transition:background 250ms,color 250ms;
}
.header-cta:hover{background:var(--accent);color:#fff}
.site-header.scrolled .header-cta{background:#132A14;color:#fff}
.site-header.scrolled .header-cta:hover{background:var(--accent)}

.mobile-toggle{
  display:none;background:none;border:none;cursor:pointer;
  padding:8px;-webkit-tap-highlight-color:transparent;
}
.mobile-toggle-bar{
  display:block;width:22px;height:1.5px;background:#fff;
  margin:5px 0;transition:background 400ms;
}
.site-header.scrolled .mobile-toggle-bar{background:#111}

.mobile-menu{
  display:none;position:fixed;inset:0;
  background:#132A14;z-index:999;
  flex-direction:column;justify-content:center;align-items:center;gap:28px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-size:clamp(24px,6vw,32px);font-weight:800;color:#fff;
  text-decoration:none;letter-spacing:-.03em;
  transition:opacity 200ms;
}
.mobile-menu a:hover{opacity:.5}
.mobile-menu-close{
  position:absolute;top:20px;right:20px;
  background:none;border:none;color:rgba(255,255,255,.6);
  font-size:28px;cursor:pointer;padding:8px;line-height:1;
}
.mobile-menu-close:hover{color:#fff}
.mobile-menu-cta{
  margin-top:16px !important;
  background:#fff !important;color:#132A14 !important;
  padding:16px 48px !important;
  font-size:18px !important;
}

@media(max-width:768px){
  .header-nav{display:none}
  .header-cta{display:none}
  .mobile-toggle{display:block}
}

/* ── Scroll Reveal ── */
.reveal{opacity:0;will-change:transform,opacity;
  transition:opacity 900ms cubic-bezier(.16,1,.3,1),
             transform 900ms cubic-bezier(.16,1,.3,1),
             filter 900ms cubic-bezier(.16,1,.3,1)}
.reveal.is-visible{opacity:1 !important;transform:none !important;filter:none !important}
.reveal.dur-1200{transition-duration:1200ms}
.reveal.dur-1500{transition-duration:1500ms}
.reveal.d-50 {transition-delay:50ms}
.reveal.d-100{transition-delay:100ms}
.reveal.d-150{transition-delay:150ms}
.reveal.d-200{transition-delay:200ms}
.reveal.d-250{transition-delay:250ms}
.reveal.d-300{transition-delay:300ms}
.reveal.d-400{transition-delay:400ms}
.reveal.d-500{transition-delay:500ms}
.reveal.d-600{transition-delay:600ms}
.reveal-fade-up{transform:translateY(32px)}
.reveal-skew{transform:translateY(48px) skewY(3deg)}
.reveal-scale{transform:scale(1.07);filter:blur(3px)}
.reveal-line{transform:scaleX(0);transform-origin:left}
.reveal-blur{transform:translateY(20px);filter:blur(8px)}
.clip-wrap{overflow:hidden;padding-bottom:4px}
.clip-wrap .reveal-clip{transform:translateY(110%)}

/* ── Buttons ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:#C9A030;color:#132A14;
  padding:14px 32px;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;border:none;cursor:pointer;min-height:44px;
  transition:background 250ms,transform 200ms,box-shadow 200ms;
}
.btn-primary:hover{background:#E8B840;transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,160,48,.4)}
.btn-primary.white{background:#fff;color:#132A14}
.btn-primary.white:hover{background:#C9A030;color:#132A14}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#132A14;
  padding:14px 32px;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;border:1.5px solid #132A14;cursor:pointer;min-height:44px;
  transition:background 250ms,color 250ms;
}
.btn-outline:hover{background:#132A14;color:#fff}
.btn-outline.white{color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline.white:hover{background:#fff;color:#132A14;border-color:#fff}

/* ── Section Layout ── */
.section-padding{padding:96px 32px}
.section-inner{max-width:1200px;margin:0 auto}
.section-inner-xl{max-width:1440px;margin:0 auto;padding:0 32px}
.section-label{
  display:inline-block;font-size:10px;font-weight:700;
  letter-spacing:.22em;color:var(--text-light);
  text-transform:uppercase;margin-bottom:20px;
}
.section-label.accent{color:var(--accent)}
.section-divider{height:1px;background:var(--border);margin-bottom:56px}
.section-title{
  font-family:'Sora',sans-serif;
  font-size:clamp(28px,4vw,44px);font-weight:800;
  letter-spacing:-.04em;line-height:1.1;
  color:var(--text-dark);margin-bottom:16px;
}
.section-title.white{color:#fff}
.section-lead{font-size:16px;color:var(--text-mid);line-height:1.75;max-width:480px}

/* ── Gallery Grid ── */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(2,280px);
  gap:6px;
}
.gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-item:nth-child(4){grid-column:span 2}
.gallery-item{
  position:relative;overflow:hidden;
  background:#1A3D1C;cursor:pointer;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 2000ms cubic-bezier(.16,1,.3,1),opacity 500ms,filter 500ms;
  opacity:.65;filter:grayscale(20%);
}
.gallery-item:hover img{transform:scale(1.08);opacity:1;filter:grayscale(0)}
.gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 55%,transparent 100%);
}
.gallery-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;
  transform:translateY(6px);
  transition:transform 400ms cubic-bezier(.16,1,.3,1);
}
.gallery-item:hover .gallery-info{transform:translateY(0)}
.gallery-loc{
  display:inline-block;background:#fff;color:#132A14;
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 10px;margin-bottom:10px;
}
.gallery-title{
  font-family:'Sora',sans-serif;
  font-size:clamp(15px,1.8vw,20px);font-weight:700;
  color:#fff;letter-spacing:-.03em;line-height:1.3;
}
.gallery-badge{
  position:absolute;top:16px;right:16px;
  background:#fff;color:#132A14;
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 14px;z-index:5;
  opacity:0;transition:opacity 300ms;
}
.gallery-item:hover .gallery-badge{opacity:1}
@media(max-width:768px){
  .gallery-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:repeat(3,200px);
    gap:4px;
  }
  .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 1}
  .gallery-item:nth-child(4){grid-column:span 2;grid-row:span 1}
}
@media(max-width:480px){
  .gallery-grid{grid-template-rows:repeat(3,160px)}
}

/* ── Hero Animations ── */
@keyframes heroLineIn{from{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}
@keyframes heroClipIn{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.overflow-clip{overflow:hidden;padding-bottom:4px}
.hero-line{animation:heroLineIn 1.2s cubic-bezier(.16,1,.3,1) both}
.hero-clip-1{animation:heroClipIn 1.4s cubic-bezier(.16,1,.3,1) .05s both}
.hero-clip-2{animation:heroClipIn 1.4s cubic-bezier(.16,1,.3,1) .2s both}
.hero-fade-cta{animation:heroFadeUp .9s cubic-bezier(.16,1,.3,1) .4s both}
.ha-eyebrow{animation:heroFadeUp .7s cubic-bezier(.16,1,.3,1) .05s both}
.ha-h1{animation:heroClipIn 1.4s cubic-bezier(.16,1,.3,1) .1s both}
.ha-sub{animation:heroFadeUp .9s cubic-bezier(.16,1,.3,1) .3s both}

/* ── Before / After Slider ── */
.ba-slider{
  position:relative;width:100%;height:60vh;min-height:380px;
  overflow:hidden;cursor:ew-resize;
  user-select:none;-webkit-user-select:none;
  touch-action:pan-y;background:#111;
}
.ba-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
}
.ba-line{
  position:absolute;top:0;bottom:0;
  width:2px;background:#fff;z-index:10;left:50%;
  box-shadow:0 0 20px rgba(0,0,0,.4);
  pointer-events:none;transform:translateX(-50%);
}
.ba-handle{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:56px;height:56px;background:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
  z-index:11;pointer-events:none;
}
.ba-badge-b,.ba-badge-a{
  position:absolute;top:20px;z-index:5;
  font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;padding:8px 16px;
}
.ba-badge-b{left:20px;background:rgba(0,0,0,.75);color:#fff}
.ba-badge-a{right:20px;background:rgba(255,255,255,.92);color:#132A14}
.ba-hint{
  position:absolute;bottom:24px;left:50%;
  transform:translateX(-50%);z-index:10;
  background:#fff;color:#132A14;
  font-size:13px;font-weight:700;letter-spacing:.02em;
  padding:10px 24px;border-radius:99px;
  white-space:nowrap;pointer-events:none;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
  animation:hint-bounce 1.6s ease-in-out infinite;
  transition:opacity 400ms;
}
@keyframes hint-bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(-7px)}
}

/* ── Trust Numbers ── */
.trust-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
}
.trust-item{
  padding:72px 48px;text-align:center;
  border-right:1px solid rgba(255,255,255,.08);
}
.trust-item:last-child{border-right:none}
.trust-num{
  font-family:'Sora',sans-serif;
  font-size:clamp(52px,8vw,92px);
  font-weight:900;color:#fff;letter-spacing:-.05em;line-height:1;
  margin-bottom:16px;
}
.trust-num-unit{font-size:.38em;font-weight:400;opacity:.55;margin-left:4px}
.trust-label{
  font-size:11px;font-weight:700;letter-spacing:.18em;
  color:rgba(255,255,255,.4);text-transform:uppercase;
}
@media(max-width:768px){
  .trust-grid{grid-template-columns:1fr}
  .trust-item{
    padding:48px 32px;border-right:none;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .trust-item:last-child{border-bottom:none}
  .trust-num{font-size:clamp(48px,12vw,72px)}
}

/* ── Service Editorial Grid ── */
.service-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:56px 80px;
}
.service-item{cursor:default}
.service-img-wrap{
  overflow:hidden;position:relative;aspect-ratio:4/3;
  border:4px solid transparent;
  transition:border-color 300ms;
}
.service-item:hover .service-img-wrap{border-color:#132A14}
.service-img-wrap img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 2000ms cubic-bezier(.16,1,.3,1);
}
.service-item:hover .service-img-wrap img{transform:scale(1.05)}
.service-info{margin-top:24px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.service-title{
  font-family:'Sora',sans-serif;
  font-size:clamp(18px,2.2vw,24px);font-weight:800;
  letter-spacing:-.04em;margin-bottom:10px;color:var(--text-dark);
  transition:color 250ms;
}
.service-item:hover .service-title{color:#132A14}
.service-desc{font-size:15px;color:var(--text-mid);line-height:1.75;max-width:380px}
.service-arrow{
  flex-shrink:0;margin-top:6px;
  width:28px;height:28px;color:#ccc;
  transition:color 250ms,transform 300ms;
}
.service-item:hover .service-arrow{color:#132A14;transform:rotate(-45deg)}
.service-link{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:16px;font-size:12px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-mid);text-decoration:none;
  transition:color 200ms;
}
.service-link:hover{color:#132A14}
@media(max-width:768px){
  .service-grid{grid-template-columns:1fr;gap:40px}
}

/* ── Process Timeline ── */
.process-timeline{display:flex;justify-content:space-between;position:relative;padding:0;max-width:900px;margin:0 auto}
.process-step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;opacity:0;transform:translateY(20px)}
.process-step.is-active{opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease}
.process-node{position:relative;margin-bottom:20px;display:flex;flex-direction:column;align-items:center}
.process-num{width:44px;height:44px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-light);background:#fff;position:relative;z-index:2;transition:border-color .4s,color .4s;font-family:'Sora',sans-serif}
.process-step.is-active .process-num{border-color:#132A14;color:#132A14}
.process-line{position:absolute;top:22px;left:50%;width:0;height:1px;background:#132A14;z-index:1;transition:width .8s ease .3s}
.process-step:last-child .process-line{display:none}
.process-step.is-active .process-line{width:calc(100% + 100px)}
.process-text h3{font-size:15px;font-weight:600;color:var(--text-dark);margin-bottom:6px;letter-spacing:-.02em}
.process-text p{font-size:14px;color:var(--text-mid);font-weight:400;line-height:1.6}
@media(max-width:768px){
  .process-timeline{flex-direction:column;gap:0;align-items:stretch}
  .process-step{flex-direction:row;align-items:flex-start;text-align:left;gap:16px;padding:20px 0;border-bottom:1px solid var(--border)}
  .process-step:last-child{border-bottom:none}
  .process-node{margin-bottom:0;flex-shrink:0}
  .process-line{display:none !important}
  .process-num{width:36px;height:36px;font-size:12px}
}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-toggle{width:100%;padding:24px 0;text-align:left;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq-q{font-size:16px;font-weight:600;color:var(--text-dark);letter-spacing:-.02em;line-height:1.5}
.faq-icon{font-size:20px;color:var(--text-light);flex-shrink:0;transition:transform .3s;font-family:monospace;font-weight:300}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-answer p{padding:0 0 24px;font-size:15px;color:var(--text-mid);line-height:1.8}
.faq-item.open .faq-answer{max-height:500px}

/* ── Floating CTA ── */
.floating-wrap{
  position:fixed;bottom:28px;right:28px;z-index:900;
  display:flex;flex-direction:column;gap:10px;align-items:flex-end;
}
.floating-top-btn{
  width:44px;height:44px;background:#fff;border:1px solid var(--border);
  display:none;align-items:center;justify-content:center;
  color:var(--text-dark);font-size:14px;cursor:pointer;
  box-shadow:0 2px 12px rgba(0,0,0,.08);
  transition:transform 200ms;
}
.floating-top-btn:hover{transform:translateY(-2px)}
.floating-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:#2E7D32;color:#fff;
  padding:13px 20px;
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;min-height:48px;
  box-shadow:0 4px 20px rgba(46,125,50,.35);
  transition:background 200ms,transform 200ms;
}
.floating-cta:hover{background:#1B5E20;transform:translateY(-2px)}
@media(max-width:768px){.floating-wrap{display:none}}

/* ── Mobile Bottom Bar ── */
.mobile-bottom{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:900;
  background:#fff;border-top:1px solid var(--border);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.mobile-bottom-steps{
  display:flex;justify-content:center;align-items:center;gap:8px;
  padding:8px 16px 0;font-size:11px;font-weight:600;color:#aaa;
}
.mobile-bottom-steps svg{color:#ccc}
.mobile-bottom-cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:#2E7D32;color:#fff;
  padding:18px;font-size:16px;font-weight:800;letter-spacing:-.02em;
  text-decoration:none;
  transition:background 200ms;
}
.mobile-bottom-cta:active{background:#1B5E20}
@media(max-width:768px){.mobile-bottom{display:block}}

/* ── CTA Section ── */
.cta-section{
  background:#132A14;padding:100px 32px;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;
  top:-40%;right:-10%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,125,50,.08),transparent 70%);
  pointer-events:none;
}
.cta-eyebrow{
  font-size:10px;font-weight:700;letter-spacing:.22em;
  color:rgba(255,255,255,.3);text-transform:uppercase;margin-bottom:24px;
}
.cta-headline{
  font-family:'Sora',sans-serif;
  font-size:clamp(28px,4.5vw,52px);
  font-weight:800;color:#fff;letter-spacing:-.04em;
  line-height:1.1;margin-bottom:16px;
}
.cta-sub{
  font-size:16px;color:rgba(255,255,255,.45);
  line-height:1.7;margin-bottom:48px;max-width:480px;
}
.cta-micro{
  margin-top:20px;font-size:12px;color:rgba(255,255,255,.25);
  letter-spacing:.04em;
}
.cta-steps{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:16px;font-size:12px;font-weight:700;
  color:rgba(255,255,255,.3);letter-spacing:.06em;text-transform:uppercase;
}

/* ── Footer ── */
.site-footer{
  background:#fff;border-top:1px solid var(--border);
  padding:64px 32px 40px;
}
.footer-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1.5fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid var(--border);
  margin-bottom:32px;
}
.footer-brand-name{
  font-family:'Sora',sans-serif;
  font-weight:800;font-size:16px;letter-spacing:.1em;
  text-transform:uppercase;color:#132A14;margin-bottom:8px;
}
.footer-brand-sub{font-size:13px;color:var(--text-light);line-height:1.7}
.footer-col-title{
  font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:#132A14;margin-bottom:16px;
}
.footer-link{
  display:block;color:var(--text-light);text-decoration:none;
  font-size:14px;padding:4px 0;transition:color 200ms;
}
.footer-link:hover{color:#132A14}
.footer-info{font-size:13px;color:var(--text-light);line-height:1.9}
.footer-bottom{
  max-width:1200px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--text-light);font-weight:500;
  flex-wrap:wrap;gap:12px;
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .site-footer{padding:48px 20px 32px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .site-footer{padding:40px 16px 28px}
}

/* ── Responsive Common ── */
@media(max-width:768px){.section-padding{padding:64px 20px}}
@media(max-width:480px){
  .section-padding{padding:48px 16px}
  .section-inner-xl{padding:0 16px}
}

/* ── Misc ── */
.cro-cta-btn{transition:background .25s,transform .2s,box-shadow .2s !important}
.cro-cta-btn:hover{transform:translateY(-2px) !important;box-shadow:0 6px 20px rgba(0,0,0,.15) !important}

/* 서비스 상세 데스크톱 스태거 */
@media(min-width:769px){
  .service-grid li:nth-child(2),
  .service-grid li:nth-child(4){margin-top:80px}
}

/* BA card (서브페이지용) */
.ba-label{
  position:absolute;bottom:10px;left:10px;
  font-size:10px;font-weight:700;letter-spacing:.14em;
  color:#fff;text-transform:uppercase;
  background:rgba(0,0,0,.65);backdrop-filter:blur(4px);
  padding:4px 10px;line-height:1;pointer-events:none;
}

/* Legacy compat (함수 출력용) */
.notice-bar{display:none !important}
.hero-badges{display:none !important}
.card-badge{display:none !important}
.trust-topbar{display:none}
.social-proof-bar{display:none}
.trust-badges-wrap{display:none}
.cta-block{display:flex;flex-direction:column;align-items:center;gap:.6rem;margin:1.5rem 0}
.cta-btn{min-width:220px}
.micro-copy{display:none}

/* 스크린리더 전용 */
.screen-reader-text{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.skip-link:focus{
  position:fixed;top:0;left:0;z-index:9999;
  width:auto;height:auto;padding:.5rem 1rem;
  background:#132A14;color:#fff;
  clip:auto;white-space:normal;
}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none !important;animation:none !important}
}
@media print{
  .site-header,.site-footer,.cta-section,.floating-wrap,.mobile-bottom{display:none}
  body{color:#000;background:#fff}
}

/* ══════════════════════════════════
   SUBPAGE STYLES
   ══════════════════════════════════ */

/* ── Page Hero ── */
.page-hero{
  background:#132A14;
  padding:144px 32px 72px;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;top:0;right:0;
  width:60%;height:100%;
  background:radial-gradient(ellipse at 70% 40%,rgba(46,125,50,.1),transparent 65%);
  pointer-events:none;
}
.page-hero-inner{max-width:1200px;margin:0 auto}
.page-hero-eyebrow{
  font-size:10px;font-weight:700;letter-spacing:.22em;
  color:rgba(255,255,255,.3);text-transform:uppercase;margin-bottom:20px;
}
.page-hero-h1{
  font-family:'Sora',sans-serif;
  font-size:clamp(36px,5.5vw,72px);
  font-weight:900;color:#fff;
  letter-spacing:-.04em;line-height:1;
  margin-bottom:24px;
}
.page-hero-sub{
  font-size:16px;color:rgba(255,255,255,.5);
  line-height:1.75;max-width:540px;
}
@media(max-width:768px){.page-hero{padding:112px 20px 56px}}

/* ── Feature Grid (3-col Why Us) ── */
.feature-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-top:48px;
}
.feature-item{
  padding:40px 32px;background:#fff;
}
.feature-num{
  font-family:'Sora',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.14em;
  color:var(--text-light);margin-bottom:20px;
}
.feature-title{
  font-family:'Sora',sans-serif;
  font-size:18px;font-weight:800;
  letter-spacing:-.03em;color:var(--text-dark);
  margin-bottom:10px;
}
.feature-desc{font-size:14px;color:var(--text-mid);line-height:1.75}
@media(max-width:768px){
  .feature-grid{grid-template-columns:1fr;gap:1px}
}

/* ── Cases Grid ── */
.cases-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:4px;margin-top:48px;
}
.case-card{
  position:relative;overflow:hidden;
  background:#1A3D1C;aspect-ratio:4/5;
  cursor:pointer;display:block;text-decoration:none;
}
.case-card img{
  width:100%;height:100%;object-fit:cover;display:block;
  opacity:.7;
  transition:transform 2000ms cubic-bezier(.16,1,.3,1),opacity 500ms;
}
.case-card:hover img{transform:scale(1.07);opacity:.9}
.case-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.2) 60%,transparent 100%);
}
.case-card-info{
  position:absolute;bottom:0;left:0;right:0;padding:28px 24px;
}
.case-card-tag{
  display:inline-block;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.8);
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:4px 10px;margin-bottom:12px;
  backdrop-filter:blur(4px);
}
.case-card-title{
  font-family:'Sora',sans-serif;
  font-size:clamp(14px,1.5vw,17px);font-weight:700;
  color:#fff;letter-spacing:-.03em;line-height:1.3;
  margin-bottom:4px;
}
.case-card-meta{font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.02em}
@media(max-width:900px){.cases-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cases-grid{grid-template-columns:1fr;gap:3px}}

/* ── Case Detail Meta Bar ── */
.case-meta-bar{
  display:flex;flex-wrap:wrap;gap:40px;
  padding:32px 0;border-bottom:1px solid var(--border);
  margin-bottom:48px;
}
.case-meta-label{
  font-size:10px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-light);margin-bottom:4px;
}
.case-meta-value{font-size:15px;font-weight:600;color:var(--text-dark)}

/* ── BA 2-col (서브페이지 Before/After) ── */
.ba-2col{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin:48px 0}
.ba-2col-item{position:relative;overflow:hidden;aspect-ratio:4/3}
.ba-2col-item img{width:100%;height:100%;object-fit:cover;display:block}
.ba-2col-label{
  position:absolute;bottom:16px;left:16px;
  font-size:10px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;padding:6px 12px;pointer-events:none;
}
.ba-2col-label.before{background:rgba(0,0,0,.75);color:#fff}
.ba-2col-label.after{background:rgba(255,255,255,.92);color:#132A14}
@media(max-width:600px){.ba-2col{grid-template-columns:1fr}}

/* ── Consult Form ── */
.consult-wrap{max-width:720px;margin:0 auto}
.consult-form-box{
  padding:48px 40px;
  background:#fff;border:1px solid var(--border);
}
.form-group{margin-bottom:24px}
.form-label{
  display:block;font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text-dark);margin-bottom:8px;
}
.form-input,.form-select,.form-textarea{
  width:100%;padding:14px 16px;
  background:var(--bg);border:1px solid var(--border);
  font-family:'Noto Sans KR',sans-serif;font-size:15px;
  color:var(--text-dark);
  transition:border-color 200ms,background 200ms;
  -webkit-appearance:none;appearance:none;
  border-radius:0;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;border-color:#132A14;background:#fff;
}
.form-textarea{resize:vertical;min-height:140px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{
  width:100%;padding:18px;
  background:#C9A030;color:#132A14;
  font-family:'Noto Sans KR',sans-serif;
  font-size:15px;font-weight:800;letter-spacing:.02em;
  border:none;cursor:pointer;
  transition:background 200ms,transform 200ms;
}
.form-submit:hover{background:#E8B840;transform:translateY(-1px)}
.form-micro{
  font-size:12px;color:var(--text-light);text-align:center;
  margin-top:16px;line-height:1.6;
}
.consult-trust-row{
  display:flex;flex-wrap:wrap;gap:24px;
  padding:32px 0;border-top:1px solid var(--border);
  margin-top:32px;
}
.consult-trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;color:var(--text-dark);
}
.consult-trust-icon{
  width:32px;height:32px;background:#132A14;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:14px;flex-shrink:0;
}
@media(max-width:768px){
  .consult-form-box{padding:32px 20px}
  .form-2col{grid-template-columns:1fr}
}

/* ── Sitemap Guide ── */
.sitemap-block{margin-bottom:48px}
.sitemap-block-title{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-light);margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.sitemap-links{list-style:none}
.sitemap-links li{border-bottom:1px solid var(--border)}
.sitemap-links a{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 0;text-decoration:none;
  color:var(--text-dark);font-size:15px;font-weight:500;
  transition:color 200ms;
}
.sitemap-links a:hover{color:#132A14}
.sitemap-links a span.arrow{
  color:var(--text-light);font-size:14px;
  transition:transform 200ms;
}
.sitemap-links a:hover span.arrow{transform:translateX(4px);color:#132A14}
.sitemap-links li.sitemap-sub a{
  padding-left:24px;font-size:14px;color:var(--text-mid);
}

/* ── Two-col text+image layout ── */
.content-2col{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:center;
}
.content-2col.reverse{direction:rtl}
.content-2col.reverse > *{direction:ltr}
@media(max-width:768px){
  .content-2col{grid-template-columns:1fr;gap:40px}
  .content-2col.reverse{direction:ltr}
}
.content-img-wrap{
  overflow:hidden;aspect-ratio:4/3;
}
.content-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}
