/* ════════════════════════════════════════════════════════════
   8FUN — style.css  (standardhaengjipsa 레퍼런스 디자인 시스템 이식)
   다크 네이비 베이스 · 실버블루 액센트 #cdd9ec · Pretendard · 샤프 코너
   ════════════════════════════════════════════════════════════ */

/* ─── RESET & TOKENS ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── DARK THEME ── 딥 네이비 베이스 + 브라스 액센트, 사례(이미지) 강조 */
  --navy:#0a1626;        /* 다크 섹션 / 히어로 / 푸터 / 이미지 플레이스홀더 */
  --navy-d:#060f1b;
  /* 액센트: 실버/화이트블루 (조용하고 고급스러운 톤) — 변수명은 호환 위해 brass 유지 */
  --brass:#cdd9ec;       /* 메인 액센트 (밝은 실버블루) */
  --brass-d:#a9bdd9;     /* 어두운 변형 — 라벨 텍스트 & 버튼 호버 */
  --brass-rgb:205,217,236;
  --white:#15263d;       /* 메인 서피스 / 카드 / 바디 배경 (라이트→다크 재매핑) */
  --gray:#101e31;        /* 대체 섹션 밴드 (서피스보다 한 단계 어둡게) */
  --text:#eef2f9;        /* 주 텍스트 (라이트) */
  --sub:#9aa7bf;         /* 보조 텍스트 */
  --border:#27394f;      /* 다크 구분선 / 보더 */
  --ff:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --max:1200px;

  /* 서브페이지 호환 토큰 (기존 클래스/인라인 var() 재매핑) */
  --bg:#101e31;
  --bg1:#101e31;
  --bg2:#0c1828;
  --bg3:#0a1422;
  --accent:#cdd9ec;
  --text-dark:#eef2f9;   /* 호환: 과거 다크 텍스트 → 이제 라이트 */
  --text-mid:#9aa7bf;
  --text-light:#6f7d96;
}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff);font-weight:400;color:var(--text);
  background:var(--white);overflow-x:hidden;font-size:16px;line-height:1.8;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  word-break:keep-all;overflow-wrap:break-word;letter-spacing:-.01em;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
.font-display{font-family:var(--ff);font-weight:800;letter-spacing:-.02em}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--brass);color:var(--navy)!important;
  font-family:var(--ff);font-weight:700;font-size:.92rem;
  padding:14px 32px;letter-spacing:.5px;border:none;cursor:pointer;
  position:relative;overflow:hidden;transition:background .25s;
  white-space:nowrap;border-radius:0;
}
.btn-primary::after{
  content:'';position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);
  animation:shimmer 2.8s cubic-bezier(.4,0,.6,1) infinite;
}
@keyframes shimmer{0%{left:-130%}100%{left:160%}}
.btn-primary:hover{background:var(--brass-d)}
.btn-primary.white{background:var(--brass);color:var(--navy)!important}
.btn-primary svg{stroke:var(--navy)}

.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text);
  font-family:var(--ff);font-weight:600;font-size:.88rem;
  padding:13px 28px;letter-spacing:.4px;
  border:1px solid var(--border);cursor:pointer;
  transition:border-color .2s,color .2s;white-space:nowrap;border-radius:0;
}
.btn-outline:hover{border-color:var(--brass);color:var(--brass-d)}
.btn-outline.white{color:#fff;border-color:rgba(255,255,255,.28)}
.btn-outline.white:hover{border-color:var(--brass);color:var(--brass)}

/* ─── REVEAL ─────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.is-visible,.reveal.visible{opacity:1;transform:none}
.reveal-clip{transform:translateY(0)}
.clip-wrap,.overflow-clip{overflow:hidden}
.d-0{transition-delay:0s}.d-50{transition-delay:.05s}.d-100{transition-delay:.1s}
.d-150{transition-delay:.15s}.d-200{transition-delay:.2s}.d-250{transition-delay:.25s}
.d-300{transition-delay:.3s}.d-400{transition-delay:.4s}.d-500{transition-delay:.5s}
.dur-1200{transition-duration:1.2s}.dur-1500{transition-duration:1.5s}
.rd1{transition-delay:.08s}.rd2{transition-delay:.16s}.rd3{transition-delay:.24s}
.rd4{transition-delay:.32s}.rd5{transition-delay:.40s}.rd6{transition-delay:.48s}

/* ─── SECTION COMMONS ────────────────────────────────────── */
.section-padding{padding:88px 24px}
.section-inner{max-width:var(--max);margin:0 auto}
.section-inner-xl{max-width:1280px;margin:0 auto;padding:0 24px}
.section-label,.sec-label{
  display:block;font-size:.66rem;font-weight:700;
  letter-spacing:3.5px;text-transform:uppercase;color:var(--brass-d);margin-bottom:10px;
}
.section-divider,.sec-rule{display:block;width:32px;height:2px;background:var(--brass);margin-bottom:16px}
.section-divider{margin-bottom:40px}
.section-title,.sec-title{
  font-size:clamp(1.75rem,3vw,2.4rem);font-weight:800;
  color:var(--text);line-height:1.15;letter-spacing:-.4px;
}
.sec-title-wh,.section-title.white{color:#fff!important}
.section-lead,.sec-sub{margin-top:14px;color:var(--sub);font-size:.97rem;line-height:1.75;max-width:520px;font-weight:400}
.sec-header{margin-bottom:52px}
.sec-header.center,.center{text-align:center}
.sec-header.center .sec-sub{margin-left:auto;margin-right:auto}

/* ─── HEADER / NAV ───────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:200;background:var(--navy);
  border-bottom:1px solid rgba(var(--brass-rgb),.2);
}
.header-inner{
  max-width:var(--max);margin:0 auto;padding:0 24px;height:62px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.header-logo{display:flex;flex-direction:column;justify-content:center;gap:4px;text-decoration:none}
.header-logo-name,.header-logo-text .header-logo-name{
  font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:.5px;line-height:1.1;
}
.header-logo-kr{color:#fff}
.header-logo-sub{font-size:.58rem;font-weight:400;color:rgba(255,255,255,.45);letter-spacing:.15px;line-height:1;white-space:nowrap}
.header-nav{display:flex;align-items:stretch;height:62px}
.header-nav a{
  display:flex;align-items:center;font-size:.72rem;font-weight:500;color:rgba(255,255,255,.55);
  padding:0 14px;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;
  white-space:nowrap;letter-spacing:.6px;text-transform:uppercase;
}
.header-nav a:hover,.header-nav a.active{color:#fff;border-bottom-color:var(--brass)}
.header-cta{
  display:inline-flex;align-items:center;background:var(--brass)!important;color:var(--navy)!important;
  font-weight:700!important;padding:0 20px!important;height:38px;
  font-size:.78rem;letter-spacing:.5px;margin-left:6px;border-radius:0;transition:background .2s;
}
.header-cta:hover{background:var(--brass-d)!important;color:var(--navy)!important}

/* mobile toggle + menu */
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle-bar{width:24px;height:2px;background:#fff;display:block}
.mobile-menu{
  position:fixed;inset:0;z-index:400;background:var(--navy);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;visibility:hidden;transition:opacity .3s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{color:rgba(255,255,255,.8);font-size:1.1rem;font-weight:600;padding:14px 24px}
.mobile-menu a:hover{color:var(--brass)}
.mobile-menu-cta{background:var(--brass);color:var(--navy)!important;font-weight:700!important;margin-top:12px}
.mobile-menu-close{position:absolute;top:24px;right:24px;background:none;border:none;color:#fff;cursor:pointer}

/* ─── BREADCRUMB ─────────────────────────────────────────── */
.breadcrumb-bar,.crumb{background:var(--gray);border-bottom:1px solid var(--border);padding:9px 24px}
.breadcrumb-inner,.crumb .wrap{
  max-width:var(--max);margin:0 auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  font-size:.73rem;color:var(--sub);letter-spacing:.2px;
}
.crumb a,.breadcrumb-inner a{color:var(--sub);transition:color .2s}
.crumb a:hover,.breadcrumb-inner a:hover{color:var(--brass)}
.crumb .sep,.breadcrumb-inner .sep{opacity:.35}

/* ─── PAGE HERO (서브페이지 공통) ────────────────────────── */
.page-hero{background:var(--navy);color:#fff;padding:64px 24px 60px;border-bottom:3px solid var(--brass)}
.page-hero-inner{max-width:var(--max);margin:0 auto}
.page-hero-eyebrow{font-size:.66rem;font-weight:700;letter-spacing:3.5px;text-transform:uppercase;color:var(--brass);margin-bottom:14px}
.page-hero-h1,.ha-h1{font-size:clamp(2rem,3.8vw,2.9rem);font-weight:800;line-height:1.15;letter-spacing:-.5px;margin-bottom:16px;color:#fff}
.page-hero-sub,.ha-sub{color:rgba(255,255,255,.6);line-height:1.85;font-weight:300;max-width:680px}
.kicker{font-size:.66rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--brass)}

/* ─── FEATURE GRID ───────────────────────────────────────── */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);background:var(--border);margin-top:48px}
.feature-item{background:var(--white);padding:32px 28px;border-top:3px solid transparent;transition:border-top-color .2s}
.feature-item:hover{border-top-color:var(--brass)}
.feature-num{font-size:.62rem;font-weight:700;letter-spacing:3px;color:var(--brass-d);margin-bottom:14px;text-transform:uppercase}
.feature-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.4}
.feature-desc{font-size:.9rem;color:var(--sub);line-height:1.75}

/* ─── CASES GRID / CARD ──────────────────────────────────── */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px}
.case-card,.gallery-item{position:relative;overflow:hidden;display:block;text-decoration:none;background:var(--navy);aspect-ratio:4/3;border-radius:0}
.case-card img,.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.04) brightness(.96) contrast(1.04);transition:transform .6s cubic-bezier(.16,1,.3,1),filter .45s}
.case-card:hover img,.gallery-item:hover img{transform:scale(1.07);filter:brightness(1.06) grayscale(0) contrast(1.06)}
.case-card-overlay,.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,26,42,.82) 0%,rgba(13,26,42,.15) 55%,transparent 100%)}
.case-card-info,.gallery-info{position:absolute;bottom:0;left:0;right:0;padding:16px 18px 18px;z-index:2}
.case-card-tag{display:inline-block;font-size:.65rem;color:var(--brass);font-weight:700;letter-spacing:.6px;margin-bottom:6px}
.gallery-badge{position:absolute;top:14px;left:14px;background:rgba(var(--brass-rgb),.12);border:1px solid rgba(var(--brass-rgb),.4);padding:4px 10px;color:var(--brass);font-size:.65rem;font-weight:700;letter-spacing:.5px;z-index:2}
.case-card-title,.gallery-title{color:#fff;font-size:.92rem;font-weight:700;line-height:1.4;margin-bottom:4px}
.case-card-meta{font-size:.72rem;color:rgba(255,255,255,.55);font-weight:500}
.gallery-loc{display:block;color:var(--brass);font-weight:700;font-size:.66rem;margin-bottom:5px}

/* ─── PROCESS TIMELINE ───────────────────────────────────── */
.process-timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);background:var(--border);margin-top:48px}
.process-step{background:var(--white);padding:36px 24px;border-top:3px solid transparent;transition:border-top-color .2s}
.process-step:hover,.process-step.is-active{border-top-color:var(--brass)}
.process-node{margin-bottom:14px}
.process-num{font-size:2.4rem;font-weight:800;color:var(--brass);line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}
.process-line{display:none}
.process-text h3{font-size:.98rem;font-weight:700;color:var(--text);margin-bottom:8px}
.process-text p{font-size:.88rem;color:var(--sub);line-height:1.7}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq-item{border-bottom:1px solid var(--border);background:var(--white)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-toggle{width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:20px 4px;display:flex;justify-content:space-between;align-items:center;gap:16px;
  border-left:3px solid transparent;transition:border-color .2s}
.faq-item.open .faq-toggle{border-left-color:var(--brass);padding-left:18px}
.faq-q{font-weight:600;font-size:.97rem;color:var(--text);line-height:1.5;text-align:left}
.faq-item.open .faq-q{color:var(--brass)}
.faq-icon{font-size:1.3rem;color:var(--brass-d);flex-shrink:0;transition:transform .3s;font-weight:300;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-answer{max-height:600px}
.faq-answer p{font-size:.92rem;color:var(--sub);line-height:1.85;padding:0 4px 22px}

/* ─── CTA SECTION (서브페이지 공통) ─────────────────────── */
.cta-section{background:var(--navy);padding:80px 24px;border-top:3px solid var(--brass)}
.cta-eyebrow{font-size:.66rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--brass);margin-bottom:14px}
.cta-headline{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:#fff;line-height:1.25;letter-spacing:-.3px;margin-bottom:14px}
.cta-sub{color:rgba(255,255,255,.6);line-height:1.75;font-weight:300}
.cta-micro{font-size:.73rem;color:rgba(255,255,255,.32);margin-top:12px;letter-spacing:.3px}
.cta-steps{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.55);font-size:.78rem;font-weight:600}
.cta-steps svg{stroke:var(--brass)}

/* ─── REGION / RELATED CARDS ─────────────────────────────── */
.region-grid,.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);background:var(--border)}
.region-card,.related-card{background:var(--white);padding:28px 26px;border-top:3px solid transparent;transition:border-top-color .2s,background .2s;display:flex;flex-direction:column;gap:14px}
.region-card:hover,.related-card:hover{border-top-color:var(--brass);background:var(--gray)}
.region-card-num{font-size:.62rem;font-weight:700;letter-spacing:2px;color:var(--brass-d);text-transform:uppercase}
.region-card-name{font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.4}
.region-card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.region-card-badge{font-size:.68rem;color:var(--sub);background:var(--gray);border:1px solid var(--border);padding:3px 10px}
.region-card-arrow{color:var(--brass-d);font-size:1.1rem;transition:transform .25s}
.region-card:hover .region-card-arrow,.related-card:hover .region-card-arrow{transform:translateX(4px)}

/* ─── CONSULT CARDS / BIZ DL ─────────────────────────────── */
.consult-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.consult-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--brass);padding:32px 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;transition:background .2s}
.consult-card:hover{background:var(--gray)}
.cc-ic{color:var(--brass-d);margin-bottom:6px}
.cc-t{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-d)}
.cc-num{font-size:1.15rem;font-weight:800;color:var(--text)}
.cc-desc{font-size:.8rem;color:var(--sub)}
.consult-note{background:var(--gray);border:1px solid var(--border);border-left:3px solid var(--brass);padding:24px 26px;margin-bottom:28px}
.cn-t{display:block;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-d);margin-bottom:12px}
.consult-note ul{display:flex;flex-direction:column;gap:8px}
.consult-note li{font-size:.88rem;color:var(--sub);line-height:1.65;padding-left:16px;position:relative}
.consult-note li::before{content:'';position:absolute;left:0;top:9px;width:6px;height:6px;background:var(--brass)}
.biz-dl{display:grid;grid-template-columns:auto 1fr;gap:0;border:1px solid var(--border)}
.biz-dl dt{background:var(--gray);padding:12px 16px;font-size:.82rem;font-weight:700;color:var(--text);border-bottom:1px solid var(--border)}
.biz-dl dd{padding:12px 16px;font-size:.85rem;color:var(--sub);border-bottom:1px solid var(--border);border-left:1px solid var(--border)}
.biz-dl dt:last-of-type,.biz-dl dd:last-of-type{border-bottom:none}
.biz-dl a{color:var(--brass-d);font-weight:600}

/* ─── GUIDE PAGES ────────────────────────────────────────── */
.guide-tldr{background:var(--gray);border:1px solid var(--border);border-left:3px solid var(--brass);padding:24px 26px;margin:32px 0}
.guide-tldr-kicker{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-d);margin-bottom:10px}
.guide-tldr-body{font-size:.95rem;color:var(--text);line-height:1.85}
.guide-checklist{display:flex;flex-direction:column;gap:12px;margin:24px 0}
.guide-checklist li{display:flex;gap:12px;align-items:flex-start;font-size:.95rem;color:var(--sub);line-height:1.7}
.guide-check-icon{color:var(--brass-d);flex-shrink:0;margin-top:2px}
.guide-table-wrap{overflow-x:auto;margin:24px 0}
.guide-table{width:100%;border-collapse:collapse;border:1px solid var(--border);font-size:.9rem}
.guide-table th{background:var(--navy);color:#fff;padding:12px 16px;text-align:left;font-weight:700}
.guide-table td{padding:12px 16px;border-top:1px solid var(--border);color:var(--sub)}
.guide-table tr:nth-child(even) td{background:var(--gray)}
.guide-caption{font-size:.78rem;color:var(--text-light);margin-top:8px}
.guide-faq,.guide-faq-item{border-bottom:1px solid var(--border)}
.guide-faq-item{padding:18px 0}
.guide-faq-item h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px}
.guide-faq-item p{font-size:.92rem;color:var(--sub);line-height:1.8}

/* ─── TRUST NUMBERS (메인 §3 호환) ──────────────────────── */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.trust-item{padding:48px 24px;text-align:center;border-right:1px solid rgba(var(--brass-rgb),.12)}
.trust-item:last-child{border-right:none}
.trust-num{font-size:2.6rem;font-weight:800;color:var(--brass);line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}
.trust-num-unit{font-size:1.2rem;opacity:.65}
.trust-label{font-size:.8rem;color:rgba(255,255,255,.5);margin-top:10px;letter-spacing:.3px}

/* ─── PORTFOLIO DETAIL helpers ───────────────────────────── */
.ba-2col{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:24px}
.ba-2col-item{position:relative;overflow:hidden;background:var(--navy)}
.ba-2col-item img{width:100%;height:100%;object-fit:cover}
.ba-2col-label{position:absolute;top:12px;left:12px;background:rgba(13,26,42,.78);color:var(--brass);font-size:.68rem;font-weight:700;padding:4px 10px;letter-spacing:.5px}
.case-meta-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:0;border:1px solid var(--border);background:var(--border);margin:24px 0}
.case-meta-bar>div{background:var(--white);padding:16px 18px}
.case-meta-label{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-d);margin-bottom:6px}
.case-meta-value{font-size:.92rem;font-weight:600;color:var(--text)}

/* ─── CASE MARQUEE (_cases_marquee) ─────────────────────── */
.case-marq-sec{overflow:hidden;padding:48px 0}
.case-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(to right,transparent,#000 5%,#000 95%,transparent)}
.case-track{display:flex;gap:12px;width:max-content;animation:marquee-scroll 50s linear infinite}
.case-marquee:hover .case-track{animation-play-state:paused}
.case-cell{width:280px;flex-shrink:0;aspect-ratio:4/3;position:relative;overflow:hidden;background:var(--navy)}
.case-cell img{width:100%;height:100%;object-fit:cover}

/* ─── SITEMAP PAGE ───────────────────────────────────────── */
.sitemap-block{margin-bottom:40px}
.sitemap-block-title{font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--brass)}
.sitemap-links{display:flex;flex-direction:column;gap:8px}
.sitemap-links a{color:var(--sub);font-size:.92rem;transition:color .2s}
.sitemap-links a:hover{color:var(--brass-d)}
.sm-fbtn{background:var(--gray);border:1px solid var(--border);padding:7px 16px;font-size:.82rem;cursor:pointer;color:var(--sub);font-weight:600}
.sm-fbtn.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ════════════════════════════════════════════════════════════
   MAIN PAGE (html.php) — 레퍼런스 섹션
   ════════════════════════════════════════════════════════════ */
.hero{background:var(--navy);border-bottom:3px solid var(--brass);position:relative;overflow:hidden}
.hero-body{max-width:var(--max);margin:0 auto;padding:64px 24px 56px;position:relative;z-index:3}
.hero-copy{max-width:620px;display:flex;flex-direction:column;justify-content:center}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.trust-badge{display:inline-flex;align-items:center;gap:6px;font-size:.71rem;font-weight:500;letter-spacing:.3px;
  background:rgba(var(--brass-rgb),.08);border:1px solid rgba(var(--brass-rgb),.25);color:rgba(255,255,255,.78);padding:5px 12px}
.hero-copy-title{font-size:clamp(2.3rem,4.2vw,3.4rem);font-weight:800;line-height:1.1;letter-spacing:-.7px;margin-bottom:16px;color:#fff}
.page-main-kw{font-size:clamp(2rem,3.8vw,3rem);font-weight:900;color:#fff;letter-spacing:-.6px;line-height:1.1;margin-bottom:6px}
.hero-sub{font-size:.96rem;font-weight:300;line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:12px}
.hero-trust-line{font-size:.76rem;font-weight:600;color:var(--brass);letter-spacing:.4px;margin-bottom:24px;opacity:.9}
.hero-cta-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.microcopy{font-size:.74rem;color:rgba(255,255,255,.4);margin-top:4px;letter-spacing:.2px}
.hero-stats{background:rgba(var(--brass-rgb),.055);border-top:1px solid rgba(var(--brass-rgb),.12);position:relative;z-index:3}
.hero-stats-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:rgba(var(--brass-rgb),.06)}
.stat-block{background:transparent;padding:20px 24px;text-align:center;border-right:1px solid rgba(var(--brass-rgb),.08);transition:background .2s}
.stat-block:last-child{border-right:none}
.stat-block:hover{background:rgba(255,255,255,.04)}
.stat-num{display:block;font-size:2rem;font-weight:800;color:var(--brass);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-1px}
.stat-unit{font-size:1rem;opacity:.65}
.stat-label{display:block;font-size:.65rem;color:rgba(255,255,255,.4);margin-top:5px;letter-spacing:.8px;text-transform:uppercase}
.v-slide{position:absolute;inset:0;opacity:0;animation:vfade 20s infinite}
.v-slide:nth-child(1){animation-delay:0s}.v-slide:nth-child(2){animation-delay:5s}
.v-slide:nth-child(3){animation-delay:10s}.v-slide:nth-child(4){animation-delay:15s}
.v-slide img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.38)}
.v-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(30,58,95,.72) 0%,rgba(30,58,95,.18) 55%,rgba(30,58,95,.55) 100%)}
@keyframes vfade{0%{opacity:0}5%{opacity:1}20%{opacity:1}25%{opacity:0}100%{opacity:0}}

.trust-sec-top{background:var(--white);border-bottom:1px solid var(--border);padding:56px 24px}
.trust-top-inner{max-width:var(--max);margin:0 auto}
.trust-badge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid rgba(var(--brass-rgb),.3);background:rgba(var(--brass-rgb),.06);margin-top:40px}
.trust-badge-card{background:var(--white);padding:36px 28px;text-align:center;border-top:3px solid var(--brass);border-right:1px solid rgba(var(--brass-rgb),.15);transition:background .2s}
.trust-badge-card:last-child{border-right:none}
.trust-badge-card:hover{background:rgba(var(--brass-rgb),.04)}
.tbcard-ic{color:var(--brass-d);margin-bottom:14px;display:flex;justify-content:center}
.tbcard-text{font-size:.95rem;font-weight:700;color:var(--text);line-height:1.5}
.tbcard-sub{font-size:.8rem;color:var(--sub);margin-top:8px;line-height:1.55}

.services{background:var(--gray);padding:88px 24px}
.services-inner{max-width:var(--max);margin:0 auto}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--border);border:1px solid var(--border);margin-top:48px}
.svc-card{background:var(--white);overflow:hidden;border-top:3px solid transparent;transition:border-top-color .22s}
.svc-card:hover{border-top-color:var(--brass)}
.svc-card>a,.svc-card-inner{display:flex;flex-direction:column;height:100%;color:inherit}
.svc-seq{font-size:.6rem;font-weight:700;letter-spacing:3px;color:var(--brass-d);padding:18px 20px 0;text-transform:uppercase}
.svc-img{aspect-ratio:16/10;overflow:hidden;background:var(--navy)}
.svc-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.12) brightness(.94);transition:filter .42s ease,transform .5s ease}
.svc-card:hover .svc-img img{filter:none;transform:scale(1.05)}
.svc-body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column}
.svc-body h3{font-size:1.02rem;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.35}
.svc-body p{font-size:.88rem;color:var(--sub);line-height:1.7;margin-bottom:14px;flex:1}
.svc-link{font-size:.72rem;font-weight:700;color:var(--brass-d);letter-spacing:.8px;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;align-self:flex-start;border-bottom:1px solid rgba(var(--brass-rgb),.38);padding-bottom:2px}

.gallery-sec{background:var(--navy);padding:88px 24px}
.gallery-inner{max-width:var(--max);margin:0 auto}
.gal-item{position:relative;overflow:hidden;display:block;text-decoration:none;background:rgba(255,255,255,.05);aspect-ratio:4/3}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.04) brightness(.94) contrast(1.04);transition:transform .6s cubic-bezier(.16,1,.3,1),filter .45s}
.gal-item:hover img{transform:scale(1.08);filter:brightness(1.05) grayscale(0) contrast(1.06)}
.gal-caption{position:absolute;bottom:0;left:0;right:0;padding:16px 18px 18px;background:linear-gradient(to top,rgba(14,27,46,.92) 0%,rgba(14,27,46,.4) 60%,transparent 100%);transform:translateY(6px);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.gal-item:hover .gal-caption{transform:translateY(0)}
.gal-tag{font-size:.65rem;color:var(--brass);font-weight:700;letter-spacing:.6px;display:block;margin-bottom:5px}
.gal-title{color:#fff;font-size:.88rem;font-weight:700;line-height:1.4;display:block}
.gal-arrow{position:absolute;top:50%;right:16px;transform:translateY(-50%) translateX(8px);opacity:0;color:var(--brass);font-size:1.4rem;transition:transform .3s,opacity .3s;pointer-events:none}
.gal-item:hover .gal-arrow{transform:translateY(-50%) translateX(0);opacity:1}
.gal-more{background:rgba(var(--brass-rgb),.06);border:1px solid rgba(var(--brass-rgb),.18);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;transition:background .3s,border-color .3s}
.gal-more:hover{background:rgba(var(--brass-rgb),.14);border-color:rgba(var(--brass-rgb),.4)}
.gal-more-icon{font-size:2rem;color:rgba(var(--brass-rgb),.5);transition:transform .3s}
.gal-more:hover .gal-more-icon{transform:scale(1.15)}
.gal-more-text{color:var(--brass);font-weight:700;font-size:.9rem;letter-spacing:.3px}
.gal-more-sub{color:rgba(255,255,255,.38);font-size:.72rem}

.process{background:var(--white);padding:88px 24px}
.process-inner{max-width:var(--max);margin:0 auto}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);background:var(--border);margin-top:48px}
.step{background:var(--white);padding:36px 24px;border-top:3px solid transparent;transition:border-top-color .2s}
.step:hover{border-top-color:var(--brass)}
.step-num{font-size:2.8rem;font-weight:800;color:var(--brass);line-height:1;margin-bottom:18px;letter-spacing:-1px;font-variant-numeric:tabular-nums;display:block}
.step h3{font-size:.98rem;font-weight:700;color:var(--text);margin-bottom:8px}
.step p{font-size:.88rem;color:var(--sub);line-height:1.7}

.why-us{background:var(--navy);padding:88px 24px;position:relative;overflow:hidden}
.why-us::before{content:'';position:absolute;top:-25%;left:50%;transform:translateX(-50%);width:1100px;height:900px;background:radial-gradient(ellipse,rgba(var(--brass-rgb),.07) 0%,transparent 62%);pointer-events:none}
.why-banner{position:relative;z-index:1;padding:0 0 56px;text-align:center}
.why-eyebrow{font-size:.62rem;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--brass);margin-bottom:16px;display:block}
.why-headline{font-size:clamp(1.8rem,4vw,2.9rem);font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.4px;max-width:640px;margin:0 auto 12px}
.why-headline em{color:var(--brass);font-style:normal}
.why-sub{font-size:.93rem;font-weight:300;color:rgba(255,255,255,.72);max-width:460px;margin:0 auto;line-height:1.85}
.why-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:rgba(var(--brass-rgb),.1);border:1px solid rgba(var(--brass-rgb),.1);margin-top:48px}
.why-card{background:rgba(255,255,255,.03);padding:36px 28px;border-top:3px solid transparent;transition:border-top-color .2s,background .2s}
.why-card:hover{border-top-color:var(--brass);background:rgba(255,255,255,.06)}
.why-ic{color:var(--brass);margin-bottom:16px;display:flex}
.why-card h4{font-size:1rem;font-weight:700;color:var(--brass);margin-bottom:10px}
.why-card p{font-size:.88rem;line-height:1.75;color:rgba(255,255,255,.78);font-weight:300}

.about-sec{background:var(--navy);padding:88px 24px;border-top:3px solid rgba(var(--brass-rgb),.18);border-bottom:3px solid rgba(var(--brass-rgb),.18);position:relative;overflow:hidden}
.about-sec .sec-title{color:#fff}.about-sec .sec-sub{color:rgba(255,255,255,.75)}
.about-body{max-width:660px;margin:0 auto;text-align:center;position:relative;z-index:1}
.about-body p{color:rgba(255,255,255,.88);line-height:2.1;margin-bottom:28px;font-size:.95rem;font-weight:300}
.about-badges{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:36px}
.about-badge{font-size:.72rem;color:rgba(255,255,255,.88);border:1px solid rgba(var(--brass-rgb),.38);padding:7px 16px;letter-spacing:.4px;background:rgba(var(--brass-rgb),.1)}

.trust-sec{background:var(--white);padding:88px 24px}
.trust-inner{max-width:var(--max);margin:0 auto}
.trust-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--navy);border:1px solid var(--navy);margin-top:48px}
.trust-stat{padding:28px 24px;text-align:center;border-right:1px solid rgba(var(--brass-rgb),.12)}
.trust-stat:last-child{border-right:none}
.tstat-num{display:block;font-size:2.4rem;font-weight:800;color:var(--brass);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-1px}
.tstat-sub{display:block;color:var(--brass);font-size:.78rem;margin-top:6px;font-weight:600}
.tstat-label{display:block;font-size:.68rem;color:rgba(255,255,255,.45);margin-top:6px;letter-spacing:.8px;text-transform:uppercase}

.reviews-marquee{overflow:hidden;padding:48px 0 52px;-webkit-mask-image:linear-gradient(to right,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(to right,transparent,#000 5%,#000 95%,transparent)}
.reviews-marquee:hover .reviews-track{animation-play-state:paused}
.reviews-track{display:flex;flex-wrap:nowrap;gap:20px;width:max-content;animation:marquee-scroll 50s linear infinite}
@keyframes marquee-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.review-card{background:var(--white);width:300px;flex-shrink:0;padding:24px;border:1px solid var(--border);border-top:3px solid transparent;transition:border-top-color .22s;display:flex;flex-direction:column}
.review-card:hover{border-top-color:var(--brass)}
.review-stars{color:var(--brass);font-size:.8rem;letter-spacing:2px;margin-bottom:14px}
.review-quote{font-size:.9rem;color:var(--text);line-height:1.8;margin-bottom:18px;flex:1}
.review-meta{font-size:.74rem;color:var(--sub);padding-top:14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.review-region{color:var(--brass-d);font-weight:700;font-size:.68rem;letter-spacing:.3px}
.review-type{font-size:.68rem;color:var(--sub);background:var(--gray);padding:3px 9px;border:1px solid var(--border)}

/* stat marquee band */
.stat-marquee-band{background:var(--brass);overflow:hidden;padding:0;line-height:1}
.stat-marquee-track{display:flex;width:max-content;animation:smq-scroll 36s linear infinite;align-items:center}
.stat-marquee-band:hover .stat-marquee-track{animation-play-state:paused}
@keyframes smq-scroll{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}
.smq-item{display:inline-flex;align-items:center;gap:10px;padding:18px 32px;white-space:nowrap;flex-shrink:0}
.smq-num{font-size:1.15rem;font-weight:900;color:var(--navy);letter-spacing:-.3px}
.smq-label{font-size:.72rem;font-weight:700;color:rgba(14,27,46,.65);letter-spacing:.4px}
.smq-sep{color:rgba(14,27,46,.3);font-size:.55rem;flex-shrink:0;padding:0 4px}

/* ─── FOOTER ─────────────────────────────────────────────── */
.site-footer{background:var(--navy);color:rgba(255,255,255,.5);padding:56px 24px 48px;font-size:.85rem;border-top:3px solid var(--brass)}
.footer-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1.4fr;gap:40px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand-name{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:.5px;margin-bottom:12px}
.footer-brand-sub{color:rgba(255,255,255,.5);line-height:1.8;font-size:.85rem}
.footer-col-title{font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--brass);margin-bottom:16px}
.footer-link{display:block;color:rgba(255,255,255,.6);font-size:.88rem;padding:5px 0;transition:color .2s}
.footer-link:hover{color:var(--brass)}
.footer-info{color:rgba(255,255,255,.5);line-height:1.85;font-size:.82rem}
.footer-bottom{max-width:var(--max);margin:24px auto 0;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;color:rgba(255,255,255,.38);font-size:.78rem}
.footer-bottom a{color:rgba(255,255,255,.5);transition:color .2s}
.footer-bottom a:hover{color:var(--brass)}
.footer-bottom strong{color:#fff}

/* ─── FLOATING / MOBILE BARS ─────────────────────────────── */
.floating-wrap{position:fixed;right:20px;bottom:24px;z-index:250;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.floating-top-btn{width:44px;height:44px;background:var(--navy);color:#fff;border:1px solid rgba(var(--brass-rgb),.3);display:none;align-items:center;justify-content:center;cursor:pointer;border-radius:0}
.floating-cta{display:inline-flex;align-items:center;gap:7px;background:var(--brass);color:var(--navy);font-weight:700;font-size:.85rem;padding:13px 22px;border-radius:0;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.floating-cta:hover{background:var(--brass-d)}
.mobile-bottom{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--navy);border-top:1px solid rgba(var(--brass-rgb),.28);padding:8px 14px;flex-direction:column;gap:6px}
.mobile-bottom-steps{display:flex;align-items:center;justify-content:center;gap:8px;color:rgba(255,255,255,.5);font-size:.7rem;font-weight:600}
.mobile-bottom-steps svg{stroke:var(--brass)}
.mobile-bottom-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--brass);color:var(--navy)!important;font-weight:700;font-size:.9rem;padding:13px;min-height:46px;border-radius:0}
.mobile-bottom-cta svg path{fill:var(--navy)}

/* ─── SKIP LINK ──────────────────────────────────────────── */
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:8px 16px;z-index:999}
.skip-link:focus{left:0}
.screen-reader-text{position:absolute;left:-9999px}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media(max-width:1200px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1024px){
  .svc-grid{grid-template-columns:1fr 1fr}.why-grid{grid-template-columns:1fr}
  .process-grid,.process-timeline{grid-template-columns:1fr 1fr}.trust-badge-grid{grid-template-columns:1fr}
  .gallery-grid,.cases-grid{grid-template-columns:1fr 1fr}
  .feature-grid,.region-grid,.related-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .header-nav{display:none}
  .mobile-toggle{display:flex}
  .floating-wrap{display:none}
  .mobile-bottom{display:flex!important}
  .consult-cards{grid-template-columns:1fr}
  .hero-body{padding:44px 20px 36px}
  .hero-sub{font-size:.9rem;margin-bottom:20px}
  .hero-badges .trust-badge:not(:first-child){display:none}
  .stat-block{padding:12px 10px}.stat-num{font-size:1.45rem}
  .hero-stats-inner{grid-template-columns:repeat(2,1fr)}
  .trust-stats{grid-template-columns:repeat(3,1fr)}
  .biz-dl{grid-template-columns:1fr}
  .biz-dl dd{border-left:none}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:640px){
  .services,.process,.trust-sec,.about-sec,.gallery-sec,.why-us,.section-padding,.cta-section{padding:56px 20px}
  .svc-grid,.why-grid,.process-grid,.process-timeline,.feature-grid,.region-grid,.related-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .trust-item{border-right:none;border-bottom:1px solid rgba(var(--brass-rgb),.12)}
  .trust-stats{grid-template-columns:1fr}
  .gallery-grid,.cases-grid{grid-template-columns:1fr 1fr;gap:2px}
  .footer-grid{grid-template-columns:1fr}
  .review-card{width:260px}
  .gal-title,.gal-more-text{font-size:.8rem}
}
@media(max-width:480px){
  .hero-body{padding:32px 16px 28px}
  .hero-copy-title{font-size:1.7rem}
  .hero-cta-wrap .btn-primary{width:100%;text-align:center;justify-content:center}
  .stat-block{padding:11px 8px}.stat-num{font-size:1.25rem}.stat-label{font-size:.55rem}
  .btn-primary{width:100%;text-align:center;justify-content:center}
}
