/* ================================================================
   1ARTWORKS — Shared Stylesheet
   Aurora, Colorado · Est. 1988
   ================================================================ */

/* ── CUSTOM PROPERTIES ── */
:root {
  --o:    #e07b00;
  --o-lt: #f5a020;
  --o-dk: #b55f00;
  --cream:#fffdf8;
  --tan:  #f7f0e0;
  --sand: #ece3ce;
  --ink:  #1e1506;
  --muted:#7a6840;
  --white:#ffffff;
  --shadow-sm: 0 2px 8px rgba(0,0,0,.08);
  --shadow-md: 0 8px 30px rgba(0,0,0,.12);
  --shadow-lg: 0 16px 60px rgba(0,0,0,.16);
  --transition: all .25s ease;
}

/* ── RESET ── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Lato',sans-serif;
  font-size:16px;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img { display:block; max-width:100%; height:auto; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ── CONTAINER ── */
.site-container {
  width:90%;
  max-width:1300px;
  margin:0 auto;
  padding:0 20px;
}

/* ── SCROLL REVEAL ── */
.rev,.rev-l,.rev-r { transition:opacity .7s ease,transform .7s ease; }
body.js-ready .rev       { opacity:0; transform:translateY(36px); }
body.js-ready .rev-l     { opacity:0; transform:translateX(-48px); }
body.js-ready .rev-r     { opacity:0; transform:translateX(48px); }
body.js-ready .rev.in,
body.js-ready .rev-l.in,
body.js-ready .rev-r.in  { opacity:1; transform:translate(0); }
.d1{transition-delay:.1s;} .d2{transition-delay:.2s;}
.d3{transition-delay:.3s;} .d4{transition-delay:.4s;}

/* ================================================================
   TOP BAR
   ================================================================ */
.site-top-bar {
  background:var(--ink);
  padding:9px 0;
  position:relative;
  z-index:99999;
}
.stb-inner {
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.stb-left {
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.stb-phone {
  font-family:'Oswald',sans-serif;
  font-size:14px;
  font-weight:600;
  color:var(--o);
  letter-spacing:.5px;
  transition:color .2s;
}
.stb-phone:hover { color:var(--o-lt); }
.stb-addr {
  font-size:12px;
  color:rgba(255,255,255,.45);
  font-weight:300;
}
.stb-right { display:flex; align-items:center; gap:16px; }
.stb-social {
  font-size:12px;
  color:rgba(255,255,255,.55);
  transition:color .2s;
  font-weight:300;
}
.stb-social:hover { color:var(--o); }

/* ================================================================
   SITE HEADER & NAVIGATION
   ================================================================ */
.site-header {
  background:#fff;
  position:sticky;
  top:0;
  z-index:99998;
  box-shadow:0 1px 0 rgba(0,0,0,.09);
  transition:box-shadow .3s;
}
.site-header.scrolled { box-shadow:0 4px 24px rgba(0,0,0,.12); }
.site-header-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 20px;
  gap:24px;
}
.site-logo-link { display:flex; align-items:center; flex-shrink:0; }
.site-logo { height:58px; width:auto; }

/* Main nav */
.site-nav { margin-left:auto; }
.nav-list {
  display:flex;
  align-items:center;
  gap:0;
}
.nav-list > li > a {
  display:block;
  padding:10px 14px;
  font-family:'Oswald',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--ink);
  position:relative;
  transition:color .2s;
}
.nav-list > li > a::after {
  content:'';
  position:absolute;
  bottom:4px;
  left:14px;
  right:14px;
  height:2px;
  background:var(--o);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}
.nav-list > li > a:hover { color:var(--o); }
.nav-list > li > a:hover::after,
.nav-list > li.active > a::after { transform:scaleX(1); }
.nav-list > li.active > a { color:var(--o); }

/* Dropdown */
.nav-has-dropdown { position:relative; }
.nav-arrow { font-size:9px; margin-left:3px; }
.nav-dropdown {
  position:absolute;
  top:calc(100% + 0px);
  left:0;
  background:#fff;
  border-top:3px solid var(--o);
  min-width:290px;
  box-shadow:var(--shadow-md);
  padding:10px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:opacity .25s,transform .25s,visibility .25s;
  z-index:10000;
}
.nav-has-dropdown:hover .nav-dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown li a {
  display:block;
  padding:8px 20px;
  font-size:13px;
  color:var(--ink);
  transition:background .2s,color .2s,padding-left .2s;
  line-height:1.4;
}
.nav-dropdown li a:hover {
  background:var(--tan);
  color:var(--o);
  padding-left:28px;
}

/* Mobile nav toggle */
.nav-toggle {
  display:none;
  flex-direction:column;
  gap:5px;
  padding:6px;
  background:none;
  border:none;
  cursor:pointer;
}
.nav-toggle span {
  display:block;
  width:24px;
  height:2px;
  background:var(--ink);
  transition:transform .3s,opacity .3s;
}
.nav-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ================================================================
   BUTTONS
   ================================================================ */
.btn {
  display:inline-block;
  padding:14px 40px;
  font-family:'Oswald',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  position:relative;
  overflow:hidden;
  transition:color .3s;
  cursor:pointer;
  border:none;
}
.btn span { position:relative; z-index:1; }
.btn::before {
  content:'';
  position:absolute;
  inset:0;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s cubic-bezier(.77,0,.18,1);
  z-index:0;
}
.btn:hover::before { transform:scaleX(1); }
.btn-fill { background:var(--o); color:#fff; }
.btn-fill::before { background:var(--o-dk); }
.btn-ghost { background:transparent; color:var(--ink); border:2px solid rgba(30,21,6,.3); }
.btn-ghost::before { background:rgba(30,21,6,.06); }
.btn-ghost:hover { border-color:var(--ink); }
.btn-out { background:transparent; color:var(--ink); border:2px solid var(--ink); }
.btn-out::before { background:var(--o); }
.btn-out:hover { color:#fff; border-color:var(--o); }
.btn-wht { background:#fff; color:var(--o-dk); }
.btn-wht::before { background:var(--sand); }
.btn-o-ghost { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.5); }
.btn-o-ghost::before { background:rgba(255,255,255,.12); }
.btn-o-ghost:hover { border-color:#fff; }

/* ================================================================
   PAGE BANNER (service pages & inner pages)
   ================================================================ */
.page-banner {
  position:relative;
  height:540px;
  min-height:360px;
  display:flex;
  align-items:flex-end;
  background-size:cover;
  background-position:center;
  overflow:hidden;
}
.page-banner-ov {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(30,21,6,.85) 0%, rgba(30,21,6,.5) 50%, rgba(30,21,6,.2) 100%);
}
.page-banner-content {
  position:relative;
  z-index:2;
  padding:60px 0;
}
.page-banner-content h1 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(36px,5vw,68px);
  font-weight:700;
  text-transform:uppercase;
  color:#fff;
  line-height:.95;
  letter-spacing:-1px;
  margin-top:10px;
  margin-bottom:14px;
}
.page-banner-content p {
  font-size:17px;
  color:rgba(255,255,255,.75);
  font-weight:300;
  max-width:520px;
  line-height:1.65;
}

/* Breadcrumb */
.breadcrumb {
  background:var(--sand);
  padding:12px 0;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.breadcrumb-inner {
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--muted);
  font-weight:300;
}
.breadcrumb-inner a { color:var(--o); transition:color .2s; }
.breadcrumb-inner a:hover { color:var(--o-dk); }
.breadcrumb-inner .sep { color:rgba(0,0,0,.25); }

/* ================================================================
   SECTIONS & LAYOUT
   ================================================================ */
.sec { padding:88px 0; }
.sec-sm { padding:64px 0; }
.bg-cream { background:var(--cream); }
.bg-tan   { background:var(--tan); }
.bg-sand  { background:var(--sand); }
.bg-ink   { background:var(--ink); }
.bg-o     { background:var(--o); }

.eyebrow {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:500;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--o);
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.eyebrow::before { content:''; width:30px; height:2px; background:var(--o); flex-shrink:0; }
.eyebrow-wht { color:rgba(255,255,255,.6); }
.eyebrow-wht::before { background:rgba(255,255,255,.4); }

.sec-title {
  font-family:'Oswald',sans-serif;
  font-size:clamp(36px,4.4vw,64px);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:-1.5px;
  line-height:.92;
  color:var(--ink);
}
.sec-title .ac { color:var(--o); }
.sec-title-wht { color:#fff; }
.sec-sub {
  margin-top:14px;
  font-size:15.5px;
  color:var(--muted);
  max-width:580px;
  line-height:1.75;
  font-weight:300;
}
.sec-sub-wht { color:rgba(255,255,255,.68); }

/* ================================================================
   HERO (Home page)
   ================================================================ */
.hero {
  position:relative;
  height:100vh;
  min-height:580px;
  overflow:hidden;
  background:var(--cream);
  display:flex;
  align-items:center;
}
.hero-slide {
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity 1.2s ease;
  display:flex;
  align-items:center;
}
.hero-slide.on { opacity:1; }
.slide-bg {
  position:absolute;
  inset:-4%;
  background-size:cover;
  background-position:center;
  transition:transform 9s ease;
}
.hero-slide.on .slide-bg    { transform:scale(1); }
.hero-slide:not(.on) .slide-bg { transform:scale(1.06); }
.slide-ov {
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,rgba(10,14,20,.92) 0%,rgba(10,14,20,.68) 50%,rgba(10,14,20,.18) 100%);
}
.hero-body {
  position:relative;
  z-index:3;
  padding:0 80px;
  max-width:860px;
}
.hero-eyebrow {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:5px;
  text-transform:uppercase;
  color:var(--o);
  margin-bottom:22px;
  display:flex;
  align-items:center;
  gap:14px;
}
.hero-eyebrow::before { content:''; width:40px; height:1px; background:var(--o); }
.hero-h1 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(58px,8vw,116px);
  font-weight:700;
  line-height:.88;
  text-transform:uppercase;
  letter-spacing:-2px;
  color:#fff;
  margin-bottom:26px;
  text-shadow:0 2px 40px rgba(0,0,0,.3);
}
.hero-h1 span { color:var(--o); }
.hero-p {
  font-size:18px;
  font-weight:300;
  line-height:1.7;
  color:rgba(255,255,255,.75);
  max-width:480px;
  margin-bottom:44px;
}
.hero-btns { display:flex; gap:16px; flex-wrap:wrap; }

/* Hero controls */
.hero-dots {
  position:absolute;
  bottom:34px;
  left:80px;
  z-index:10;
  display:flex;
  gap:10px;
  align-items:center;
}
.hdot {
  height:3px;
  background:rgba(255,255,255,.3);
  border:none;
  cursor:pointer;
  padding:0;
  transition:all .3s;
  width:28px;
}
.hdot.on { background:var(--o); width:52px; }
.scroll-cue {
  position:absolute;
  bottom:34px;
  right:80px;
  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  font-family:'Oswald',sans-serif;
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.scroll-line {
  width:1px;
  height:56px;
  background:linear-gradient(var(--o),transparent);
  animation:spulse 1.8s ease-in-out infinite;
}
@keyframes spulse { 0%,100%{opacity:.3;} 50%{opacity:1;} }

/* ================================================================
   ACTION STRIP
   ================================================================ */
.astrip {
  background:var(--ink);
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.aitem {
  display:flex;
  align-items:center;
  gap:18px;
  padding:26px 36px;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .25s;
}
.aitem:last-child { border-right:none; }
.aitem:hover { background:var(--o); }
.aitem-num {
  font-family:'Oswald',sans-serif;
  font-size:38px;
  font-weight:700;
  color:var(--o);
  line-height:1;
  flex-shrink:0;
  transition:color .25s;
}
.aitem:hover .aitem-num { color:#fff; }
.aitem-label strong {
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:15px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#fff;
  margin-bottom:3px;
}
.aitem-label span { font-size:12px; color:rgba(255,255,255,.5); font-weight:300; }
.aitem-arrow {
  margin-left:auto;
  flex-shrink:0;
  font-size:18px;
  color:var(--o);
  transition:transform .25s,color .25s;
}
.aitem:hover .aitem-arrow { transform:translateX(5px); color:#fff; }

/* ================================================================
   CONTENT BLOCKS (2-col image + text)
   ================================================================ */
.cblock {
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:520px;
  overflow:hidden;
}
.cblock.flip { direction:rtl; }
.cblock.flip > * { direction:ltr; }
.cblock-img { position:relative; overflow:hidden; min-height:440px; }
.cblock-img img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .9s cubic-bezier(.25,1,.5,1);
}
.cblock:hover .cblock-img img { transform:scale(1.05); }
.cblock-text {
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:72px 80px;
}
.cblock-text.bg-o  { background:var(--o); }
.cblock-text.bg-cr { background:var(--cream); }
.cblock-text.bg-tn { background:var(--tan); }
.cblock-text.bg-sd { background:var(--sand); }

.cb-kk {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:500;
  letter-spacing:4px;
  text-transform:uppercase;
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:10px;
}
.bg-o .cb-kk { color:rgba(255,255,255,.65); }
.bg-o .cb-kk::before { background:rgba(255,255,255,.4); }
.bg-cr .cb-kk,.bg-tn .cb-kk,.bg-sd .cb-kk { color:var(--o); }
.bg-cr .cb-kk::before,.bg-tn .cb-kk::before,.bg-sd .cb-kk::before { background:var(--o); }
.cb-kk::before { content:''; display:block; width:26px; height:2px; }
.cb-h {
  font-family:'Oswald',sans-serif;
  font-size:clamp(30px,3.2vw,52px);
  font-weight:700;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:-1px;
  margin-bottom:20px;
}
.bg-o .cb-h { color:#fff; }
.bg-cr .cb-h,.bg-tn .cb-h,.bg-sd .cb-h { color:var(--ink); }
.cb-p { font-size:15.5px; line-height:1.75; font-weight:300; margin-bottom:28px; }
.bg-o .cb-p { color:rgba(255,255,255,.78); }
.bg-cr .cb-p,.bg-tn .cb-p,.bg-sd .cb-p { color:var(--muted); }

.cb-list { list-style:none; display:flex; flex-direction:column; gap:0; margin-bottom:34px; }
.cb-list li {
  font-size:14px;
  display:flex;
  align-items:flex-start;
  gap:10px;
  line-height:1.4;
  padding:10px 0;
  border-bottom:1px solid;
}
.cb-list li:first-child { border-top:1px solid; }
.bg-o .cb-list li { color:rgba(255,255,255,.72); border-color:rgba(255,255,255,.1); }
.bg-cr .cb-list li,.bg-tn .cb-list li,.bg-sd .cb-list li { color:var(--muted); border-color:var(--sand); }
.cb-list li::before {
  content:attr(data-n);
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:1px;
  margin-top:1px;
  flex-shrink:0;
  min-width:22px;
}
.bg-o .cb-list li::before { color:rgba(255,255,255,.35); }
.bg-cr .cb-list li::before,.bg-tn .cb-list li::before,.bg-sd .cb-list li::before { color:var(--o); }

/* ================================================================
   PULLQUOTES
   ================================================================ */
.pq {
  padding:68px 80px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  position:relative;
}
.pq-o { background:var(--o); }
.pq-tn { background:var(--tan); }
.pq-sd { background:var(--sand); }
.pq::before {
  content:'\201C';
  position:absolute;
  top:-30px;
  left:3%;
  font-family:'Oswald',sans-serif;
  font-size:260px;
  font-weight:700;
  line-height:1;
  pointer-events:none;
  z-index:0;
}
.pq-o::before { color:rgba(255,255,255,.06); }
.pq-tn::before,.pq-sd::before { color:rgba(30,21,6,.04); }
.pq-inner { max-width:860px; position:relative; z-index:1; }
.pq-text {
  font-family:'Oswald',sans-serif;
  font-size:clamp(20px,2.8vw,38px);
  font-weight:600;
  line-height:1.1;
  text-transform:uppercase;
  letter-spacing:-.5px;
}
.pq-o .pq-text { color:#fff; }
.pq-tn .pq-text,.pq-sd .pq-text { color:var(--ink); }
.pq-cite {
  display:block;
  margin-top:16px;
  font-size:11px;
  font-weight:400;
  letter-spacing:3px;
  text-transform:uppercase;
}
.pq-o .pq-cite { color:rgba(255,255,255,.45); }
.pq-tn .pq-cite,.pq-sd .pq-cite { color:var(--o); }

/* ================================================================
   SERVICE CARDS GRID
   ================================================================ */
.svc-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin-top:52px;
  border:2px solid var(--sand);
}
.svc-card {
  background:var(--cream);
  padding:44px 36px;
  border-right:2px solid var(--sand);
  border-bottom:2px solid var(--sand);
  position:relative;
  overflow:hidden;
  transition:background .35s;
}
.svc-card:nth-child(3n) { border-right:none; }
.svc-card::before {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:4px;
  background:var(--o);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s cubic-bezier(.77,0,.18,1);
}
.svc-card:hover::before { transform:scaleX(1); }
.svc-card:hover { background:var(--tan); }
.svc-n {
  font-family:'Oswald',sans-serif;
  font-size:56px;
  font-weight:700;
  color:var(--o);
  line-height:1;
  margin-bottom:16px;
  display:block;
  transition:color .35s;
}
.svc-card:hover .svc-n { color:var(--o-lt); }
.svc-name {
  font-family:'Oswald',sans-serif;
  font-size:20px;
  font-weight:600;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:10px;
}
.svc-desc { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:18px; font-weight:300; }
.svc-items { display:flex; flex-direction:column; gap:7px; }
.svc-row {
  font-size:13px;
  color:var(--muted);
  display:flex;
  align-items:center;
  gap:10px;
  transition:color .25s;
}
.svc-card:hover .svc-row { color:var(--ink); }
.svc-row::before {
  content:'';
  display:block;
  width:14px;
  height:1px;
  background:var(--o);
  flex-shrink:0;
  transition:width .25s;
}
.svc-card:hover .svc-row::before { width:22px; }
.svc-more {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:'Oswald',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  margin-top:22px;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .3s,transform .3s;
}
.svc-card:hover .svc-more { opacity:1; transform:translateY(0); }

/* ================================================================
   STATS BAR
   ================================================================ */
.stats {
  background:#0d1b2a;
  padding:80px 0;
  overflow:hidden;
  position:relative;
}
.stats::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0; bottom:0;
  background:radial-gradient(ellipse at 60% 50%, rgba(224,123,0,.08) 0%, transparent 70%);
  pointer-events:none;
}
.stats-in {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  position:relative;
  z-index:2;
}
.stat {
  text-align:center;
  padding:32px 24px;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat:last-child { border-right:none; }
.stat-n {
  font-family:'Oswald',sans-serif;
  font-size:clamp(52px,5.5vw,84px);
  font-weight:700;
  color:var(--o);
  line-height:1;
  display:block;
}
.stat-l {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:400;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
  margin-top:12px;
}

/* ================================================================
   INDUSTRY TILES
   ================================================================ */
.ind-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:4px;
  margin-top:52px;
}
.ind-tile {
  position:relative;
  height:250px;
  overflow:hidden;
  background:var(--ink);
}
.ind-tile img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.5;
  transition:opacity .5s,transform .7s cubic-bezier(.25,1,.5,1);
}
.ind-tile:hover img { opacity:.28; transform:scale(1.1); }
.ind-tile::after {
  content:'';
  position:absolute;
  bottom:0; left:0;
  height:3px;
  width:0;
  background:var(--o);
  transition:width .5s ease;
}
.ind-tile:hover::after { width:100%; }
.ind-info {
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:26px 22px;
  background:linear-gradient(to top,rgba(30,21,6,.88) 0%,transparent 65%);
}
.ind-name {
  font-family:'Oswald',sans-serif;
  font-size:19px;
  font-weight:600;
  text-transform:uppercase;
  color:#fff;
  line-height:1;
  margin-bottom:6px;
  transform:translateY(4px);
  transition:transform .3s;
}
.ind-tile:hover .ind-name { transform:translateY(0); }
.ind-go {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o-lt);
  opacity:0;
  transform:translateY(7px);
  transition:opacity .3s,transform .3s;
}
.ind-tile:hover .ind-go { opacity:1; transform:translateY(0); }

/* ================================================================
   PORTFOLIO MOSAIC (home page)
   ================================================================ */
.mosaic {
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:270px 230px 200px;
  gap:4px;
  margin-top:52px;
}
.mc { overflow:hidden; position:relative; background:var(--sand); display:block; text-decoration:none; cursor:pointer; }
.mc:nth-child(1) { grid-column:span 5; grid-row:span 2; }
.mc:nth-child(2) { grid-column:span 4; }
.mc:nth-child(3) { grid-column:span 3; }
.mc:nth-child(4) { grid-column:span 4; }
.mc:nth-child(5) { grid-column:span 3; }
.mc:nth-child(6) { grid-column:span 3; }
.mc:nth-child(7) { grid-column:span 3; }
.mc:nth-child(8) { grid-column:span 3; }
.mc:nth-child(9) { grid-column:span 3; }
.mc img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s cubic-bezier(.25,1,.5,1);
}
.mc:hover img { transform:scale(1.09); }
.mc-ov {
  position:absolute;
  inset:0;
  background:rgba(224,123,0,.88);
  opacity:0;
  transition:opacity .35s;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.mc:hover .mc-ov { opacity:1; }
.mc-lbl {
  font-family:'Oswald',sans-serif;
  font-size:16px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:#fff;
  transform:translateY(12px);
  transition:transform .3s .05s;
}
.mc:hover .mc-lbl { transform:translateY(0); }
.mc-sub {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.65);
  transform:translateY(12px);
  transition:transform .3s .1s;
}
.mc:hover .mc-sub { transform:translateY(0); }

/* ================================================================
   PORTFOLIO PAGE GRID
   ================================================================ */
.port-filters {
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:40px;
}
.port-filter {
  padding:8px 22px;
  font-family:'Oswald',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  border:2px solid var(--sand);
  background:var(--cream);
  color:var(--muted);
  transition:all .25s;
  cursor:pointer;
}
.port-filter:hover,.port-filter.active {
  background:var(--o);
  border-color:var(--o);
  color:#fff;
}
.port-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.port-item {
  position:relative;
  overflow:hidden;
  background:var(--sand);
  aspect-ratio:4/3;
}
.port-item img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s cubic-bezier(.25,1,.5,1);
  display:block;
}
.port-item:hover img { transform:scale(1.08); }
.port-item-ov {
  position:absolute;
  inset:0;
  background:rgba(224,123,0,.9);
  opacity:0;
  transition:opacity .3s;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:24px;
  text-align:center;
}
.port-item:hover .port-item-ov { opacity:1; }
.port-item-name {
  font-family:'Oswald',sans-serif;
  font-size:18px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#fff;
  transform:translateY(10px);
  transition:transform .3s .05s;
}
.port-item:hover .port-item-name { transform:translateY(0); }
.port-item-cat {
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  font-family:'Oswald',sans-serif;
  transform:translateY(10px);
  transition:transform .3s .1s;
}
.port-item:hover .port-item-cat { transform:translateY(0); }

/* ================================================================
   PROCESS LIST
   ================================================================ */
.process-list {
  margin-top:52px;
  border:2px solid var(--sand);
  display:flex;
  flex-direction:column;
}
.proc-row {
  display:flex;
  border-bottom:2px solid var(--sand);
  overflow:hidden;
  position:relative;
  transition:background .3s;
}
.proc-row:last-child { border-bottom:none; }
.proc-row:hover { background:var(--tan); }
.proc-row::before {
  content:'';
  position:absolute;
  top:0; left:0; bottom:0;
  width:4px;
  background:var(--o);
  transform:scaleY(0);
  transform-origin:top;
  transition:transform .38s ease;
}
.proc-row:hover::before { transform:scaleY(1); }
.proc-num {
  font-family:'Oswald',sans-serif;
  font-size:76px;
  font-weight:700;
  color:var(--o);
  line-height:1;
  flex-shrink:0;
  padding:34px 40px 34px 54px;
  width:160px;
  transition:color .3s;
}
.proc-row:hover .proc-num { color:var(--o-lt); }
.proc-div {
  width:2px;
  background:var(--sand);
  flex-shrink:0;
  margin:28px 0;
}
.proc-body {
  padding:34px 48px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.proc-title {
  font-family:'Oswald',sans-serif;
  font-size:22px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--ink);
  margin-bottom:9px;
}
.proc-desc {
  font-size:15px;
  color:var(--muted);
  line-height:1.7;
  font-weight:300;
  max-width:680px;
}
.proc-tag {
  margin-top:12px;
  font-family:'Oswald',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  opacity:0;
  transform:translateX(-8px);
  transition:opacity .3s,transform .3s;
}
.proc-row:hover .proc-tag { opacity:1; transform:translateX(0); }

/* ================================================================
   ABOUT SECTION
   ================================================================ */
.about-grid {
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:80px;
  align-items:center;
}
.about-img-wrap { position:relative; }
.about-img-wrap img {
  width:100%;
  height:520px;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:1;
}
.about-img-wrap::before {
  content:'';
  position:absolute;
  top:-16px; left:-16px; right:16px; bottom:16px;
  border:3px solid var(--o);
  z-index:0;
  transition:transform .4s;
}
.about-img-wrap:hover::before { transform:translate(4px,4px); }
.about-badge {
  position:absolute;
  bottom:20px; right:-28px;
  z-index:2;
  width:118px; height:118px;
  background:var(--o);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.badge-n {
  font-family:'Oswald',sans-serif;
  font-size:44px;
  font-weight:700;
  color:#fff;
  line-height:1;
}
.badge-l {
  font-size:9px;
  font-weight:400;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  margin-top:3px;
}
.about-quote {
  font-family:'Oswald',sans-serif;
  font-size:17px;
  font-weight:400;
  font-style:italic;
  color:var(--ink);
  line-height:1.55;
  border-left:4px solid var(--o);
  padding:16px 22px;
  background:#fff;
  margin:24px 0;
}
.about-body p {
  font-size:15px;
  color:var(--muted);
  line-height:1.8;
  margin-bottom:15px;
  font-weight:300;
}
.about-body p:last-child { margin-bottom:0; }
.about-body strong { color:var(--o-dk); font-weight:700; }

/* Contact rows */
.ctc-rows {
  display:flex;
  flex-direction:column;
  gap:0;
  margin-top:28px;
  border-top:2px solid var(--sand);
}
.ctc-row {
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:14px 0;
  border-bottom:1px solid var(--sand);
  font-size:14.5px;
  color:var(--ink);
  transition:color .2s;
}
.ctc-row:hover { color:var(--o); }
.ctc-lbl {
  font-family:'Oswald',sans-serif;
  font-size:10px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  min-width:64px;
  margin-top:2px;
}

/* ================================================================
   CTA SLAB
   ================================================================ */
.cta-slab {
  background:var(--o);
  padding:88px 0;
  overflow:hidden;
  position:relative;
}
.cta-slab::before {
  content:'';
  position:absolute;
  top:0; right:0; bottom:0;
  width:45%;
  background:var(--o-dk);
  clip-path:polygon(15% 0,100% 0,100% 100%,0 100%);
  opacity:.4;
}
.cta-in {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:60px;
  flex-wrap:wrap;
  position:relative;
  z-index:2;
}
.cta-in h2 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(30px,3.8vw,58px);
  font-weight:700;
  text-transform:uppercase;
  color:#fff;
  line-height:.92;
  letter-spacing:-1px;
  margin-bottom:12px;
}
.cta-in p { font-size:17px; color:rgba(255,255,255,.78); font-weight:300; }
.cta-btns { display:flex; gap:14px; flex-wrap:wrap; flex-shrink:0; }

/* ================================================================
   SERVICE PAGE: Feature Grid
   ================================================================ */
.feat-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:4px;
  margin-top:52px;
}
.feat-card {
  background:var(--tan);
  padding:40px 36px;
  position:relative;
  overflow:hidden;
  transition:background .3s;
}
.feat-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--o);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s;
}
.feat-card:hover::before { transform:scaleX(1); }
.feat-card:hover { background:var(--cream); }
.feat-icon {
  font-family:'Oswald',sans-serif;
  font-size:48px;
  font-weight:700;
  color:var(--sand);
  display:block;
  margin-bottom:14px;
  line-height:1;
  transition:color .3s;
}
.feat-card:hover .feat-icon { color:var(--o); }
.feat-title {
  font-family:'Oswald',sans-serif;
  font-size:20px;
  font-weight:600;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:10px;
}
.feat-desc { font-size:14px; color:var(--muted); line-height:1.7; font-weight:300; }

/* Service detail content */
.svc-detail { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.svc-detail-img {
  position:relative;
  overflow:hidden;
}
.svc-detail-img img {
  width:100%;
  height:480px;
  object-fit:cover;
  display:block;
}
.svc-detail-body { padding:20px 0; }
.svc-detail-body h2 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(28px,3vw,44px);
  font-weight:700;
  text-transform:uppercase;
  color:var(--ink);
  letter-spacing:-1px;
  line-height:.95;
  margin-bottom:20px;
}
.svc-detail-body h2 span { color:var(--o); }
.svc-detail-body p {
  font-size:15px;
  color:var(--muted);
  line-height:1.8;
  margin-bottom:16px;
  font-weight:300;
}
.svc-list {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:0;
  margin:24px 0 32px;
  border-top:2px solid var(--sand);
}
.svc-list li {
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:12px 0;
  border-bottom:1px solid var(--sand);
  font-size:14.5px;
  color:var(--muted);
  font-weight:300;
}
.svc-list li::before {
  content:'→';
  color:var(--o);
  font-family:'Oswald',sans-serif;
  font-weight:600;
  flex-shrink:0;
  margin-top:1px;
}

/* Gallery strip on service pages */
.svc-gallery {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:4px;
  margin-top:52px;
}
.svc-gal-item {
  position:relative;
  overflow:hidden;
  background:var(--sand);
  aspect-ratio:16/10;
}
.svc-gal-item img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s cubic-bezier(.25,1,.5,1);
}
.svc-gal-item:hover img { transform:scale(1.08); }

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-grid {
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:80px;
  align-items:start;
}
.contact-info h2 {
  font-family:'Oswald',sans-serif;
  font-size:38px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--ink);
  letter-spacing:-1px;
  line-height:.95;
  margin-bottom:20px;
}
.contact-info h2 span { color:var(--o); }
.contact-info p {
  font-size:15px;
  color:var(--muted);
  line-height:1.8;
  font-weight:300;
  margin-bottom:24px;
}
.contact-details {
  display:flex;
  flex-direction:column;
  gap:0;
  border-top:2px solid var(--sand);
}
.cd-row {
  display:flex;
  gap:16px;
  padding:16px 0;
  border-bottom:1px solid var(--sand);
  align-items:flex-start;
}
.cd-label {
  font-family:'Oswald',sans-serif;
  font-size:10px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  min-width:64px;
  margin-top:2px;
  flex-shrink:0;
}
.cd-val {
  font-size:14.5px;
  color:var(--ink);
  font-weight:300;
  line-height:1.5;
}
.cd-val a { color:var(--ink); transition:color .2s; }
.cd-val a:hover { color:var(--o); }

.hours-table { display:flex; flex-direction:column; gap:4px; margin-top:28px; }
.hours-row {
  display:flex;
  justify-content:space-between;
  font-size:13.5px;
  padding:8px 0;
  border-bottom:1px solid var(--sand);
}
.hours-row:last-child { border-bottom:none; }
.hours-row span:first-child { color:var(--ink); font-weight:400; }
.hours-row span:last-child { color:var(--muted); font-weight:300; }

/* Contact form */
.contact-form-wrap {
  background:var(--cream);
  border:2px solid var(--sand);
  padding:48px 44px;
}
.form-title {
  font-family:'Oswald',sans-serif;
  font-size:26px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:28px;
  letter-spacing:-.5px;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-group label {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
}
.form-group input,
.form-group select,
.form-group textarea {
  background:#fff;
  border:2px solid var(--sand);
  padding:12px 16px;
  font-family:'Lato',sans-serif;
  font-size:14px;
  color:var(--ink);
  transition:border-color .25s;
  outline:none;
  -webkit-appearance:none;
  border-radius:0;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--o); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-success {
  display:none;
  background:var(--tan);
  border-left:4px solid var(--o);
  padding:16px 20px;
  font-size:14px;
  color:var(--ink);
  margin-top:16px;
}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer {
  background:#0d1b2a;
  border-top:4px solid var(--o);
}
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:52px;
  padding:72px 0 56px;
}
.ft-name {
  font-family:'Oswald',sans-serif;
  font-size:28px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--o);
}
.ft-tag {
  font-size:10px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.38);
  font-weight:400;
  display:block;
  margin-top:2px;
  margin-bottom:18px;
}
.ft-body { font-size:13.5px; color:rgba(255,255,255,.5); line-height:1.75; font-weight:300; }
.ft-phone {
  display:block;
  margin-top:16px;
  font-family:'Oswald',sans-serif;
  font-size:22px;
  font-weight:600;
  color:var(--o);
  transition:color .2s;
}
.ft-phone:hover { color:var(--o-lt); }
.footer-col h4 {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.38);
  margin-bottom:18px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-col ul { display:flex; flex-direction:column; gap:10px; }
.footer-col ul a {
  font-size:13.5px;
  color:rgba(255,255,255,.55);
  transition:color .2s,padding-left .2s;
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:300;
}
.footer-col ul a::before {
  content:'';
  display:block;
  width:0;
  height:1px;
  background:var(--o);
  transition:width .25s;
  flex-shrink:0;
}
.footer-col ul a:hover { color:var(--o); padding-left:4px; }
.footer-col ul a:hover::before { width:14px; }
.fhr { display:flex; flex-direction:column; gap:4px; }
.fhr-row {
  display:flex;
  justify-content:space-between;
  font-size:13px;
  gap:10px;
  padding-bottom:6px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.fhr-row:last-child { border-bottom:none; }
.fhr-row span:first-child { color:rgba(255,255,255,.65); font-weight:400; }
.fhr-row span:last-child { color:rgba(255,255,255,.38); font-weight:300; }

.footer-bottom {
  border-top:1px solid rgba(255,255,255,.1);
  padding:18px 0;
}
.footer-bottom .site-container {
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.ft-copy { font-size:12px; color:rgba(255,255,255,.3); font-weight:300; }
.ft-links { display:flex; gap:20px; }
.ft-links a { font-size:12px; color:rgba(255,255,255,.38); transition:color .2s; }
.ft-links a:hover { color:var(--o); }

/* ================================================================
   MARQUEE TICKER STRIP
   ================================================================ */
.marquee-strip {
  background:var(--o);
  overflow:hidden;
  padding:13px 0;
  display:flex;
  gap:0;
  position:relative;
  z-index:10;
}
.marquee-track {
  display:flex;
  align-items:center;
  flex-shrink:0;
  min-width:100%;
  animation:mq-scroll 38s linear infinite;
}
.marquee-track:nth-child(2) { animation-delay:-19s; }
.mq-item {
  display:inline-flex;
  align-items:center;
  gap:28px;
  padding:0 28px;
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:#fff;
  white-space:nowrap;
}
.mq-dot {
  display:inline-block;
  width:5px;
  height:5px;
  border-radius:50%;
  background:rgba(255,255,255,.4);
  flex-shrink:0;
}
@keyframes mq-scroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-100%); }
}
@media (prefers-reduced-motion:reduce) { .marquee-track { animation:none; } }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1200px) {
  .cblock { grid-template-columns:1fr; }
  .cblock.flip { direction:ltr; }
  .cblock-img { min-height:360px; height:400px; }
  .cblock-text { padding:60px 48px; }
  .about-grid { grid-template-columns:1fr; gap:60px; }
  .about-badge { right:12px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .svc-detail { grid-template-columns:1fr; gap:40px; }
  .svc-detail-img img { height:340px; }
  .contact-grid { grid-template-columns:1fr; gap:48px; }
  .cta-in { flex-direction:column; align-items:flex-start; }
}
@media (max-width:980px) {
  .nav-toggle { display:flex; }
  .site-nav {
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#fff;
    border-top:3px solid var(--o);
    box-shadow:var(--shadow-md);
    max-height:0;
    overflow:hidden;
    overflow-y:auto;
    transition:max-height .4s ease;
  }
  .site-nav.open { max-height:80vh; }
  .nav-list { flex-direction:column; align-items:stretch; padding:8px 0; gap:0; }
  .nav-list > li > a { padding:12px 20px; font-size:14px; }
  .nav-list > li > a::after { display:none; }
  .nav-dropdown {
    position:static;
    border-top:none;
    border-left:3px solid var(--o);
    box-shadow:none;
    opacity:1;
    visibility:visible;
    transform:none;
    display:none;
    margin:0 0 8px 20px;
    min-width:auto;
    padding:4px 0;
    background:var(--cream);
  }
  .nav-has-dropdown.open .nav-dropdown { display:block; }
  .nav-dropdown li a { padding:9px 16px; font-size:13px; }

  .astrip { grid-template-columns:1fr 1fr; }
  .aitem { border-right:none; border-bottom:1px solid rgba(255,255,255,.07); padding:20px 22px; }
  .aitem:nth-child(odd) { border-right:1px solid rgba(255,255,255,.07); }
  .aitem:last-child { border-bottom:none; }

  .stb-addr { display:none; }
  .stats-in { grid-template-columns:repeat(2,1fr); }
  .ind-grid { grid-template-columns:repeat(2,1fr); }
  .svc-grid { grid-template-columns:repeat(2,1fr); }

  .mosaic {
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:auto;
  }
  .mc {
    height:200px;
    grid-column:span 1 !important;
    grid-row:span 1 !important;
  }

  .proc-num { font-size:52px; padding:26px 20px 26px 32px; width:100px; }
  .proc-body { padding:26px 24px; }

  .port-grid { grid-template-columns:repeat(2,1fr); }
  .feat-grid { grid-template-columns:1fr; }
  .svc-gallery { grid-template-columns:repeat(2,1fr); }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:767px) {
  .sec { padding:60px 0; }
  .hero-body { padding:0 24px; }
  .hero-dots { left:24px; }
  .scroll-cue { right:24px; }
  .pq { padding:52px 24px; }
  .cblock-text { padding:48px 24px; }
  .stats-in { padding:0 16px; }
  .svc-grid { grid-template-columns:1fr; }
  .svc-card:nth-child(n) { border-right:none; }
  .ind-grid { grid-template-columns:1fr 1fr; }
  .ind-tile { height:200px; }
  .port-grid { grid-template-columns:1fr; }
  .proc-num { display:none; }
  .proc-div { display:none; }
  .footer-grid { grid-template-columns:1fr; padding:40px 0 32px; }
  .footer-bottom .site-container { flex-direction:column; text-align:center; }
  .contact-form-wrap { padding:32px 24px; }
  .cta-in { gap:32px; }
}
@media (max-width:479px) {
  .astrip { grid-template-columns:1fr; }
  .aitem { border-right:none !important; }
  .ind-grid { grid-template-columns:1fr; }
  .svc-gallery { grid-template-columns:1fr; }
}

/* ================================================================
   ADDITIONAL UTILITIES & ALIASES (inner pages)
   ================================================================ */

/* Background utilities */
.bg-cr  { background:var(--cream); }
.bg-wh  { background:#fff; }
.bg-tn  { background:var(--tan); }
.bg-sd  { background:var(--sand); }

/* Section spacing */
.section-pad { padding:88px 0; }
.text-center { text-align:center; }

/* Section headings */
.section-title {
  font-family:'Oswald',sans-serif;
  font-size:clamp(36px,4.4vw,64px);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:-1.5px;
  line-height:.92;
  color:var(--ink);
  margin-bottom:16px;
}
.section-sub {
  font-size:15.5px;
  color:var(--muted);
  line-height:1.75;
  font-weight:300;
}

/* ── Page banner overlay & inner ── */
.page-banner::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(10,14,20,.97) 0%,rgba(10,14,20,.75) 30%,rgba(10,14,20,.3) 65%,rgba(10,14,20,.05) 100%);
  z-index:1;
}
.pb-inner { position:relative; z-index:20; padding:0 0 52px; width:100%; }
.pb-title {
  font-family:'Oswald',sans-serif;
  font-size:clamp(34px,4.5vw,62px);
  font-weight:700;
  text-transform:uppercase;
  color:#fff;
  line-height:.92;
  letter-spacing:-1.5px;
  margin-bottom:14px;
  text-shadow:0 2px 20px rgba(0,0,0,.5);
}
/* breadcrumb inside dark banner */
.page-banner .breadcrumb {
  background:transparent;
  border:none;
  padding:0;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:300;
}
.page-banner .breadcrumb a { color:var(--o-lt); transition:color .2s; }
.page-banner .breadcrumb a:hover { color:#fff; }
.page-banner .breadcrumb span { color:rgba(255,255,255,.45); }

/* ── Content block aliases ── */
.cblock .cb-img { position:relative; overflow:hidden; min-height:440px; }
.cblock .cb-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cblock .cb-text { display:flex; flex-direction:column; justify-content:center; padding:72px 80px; }
.cblock.cb-flip { direction:rtl; }
.cblock.cb-flip > * { direction:ltr; }

/* pq z-index fix when using .site-container as inner */
.pq > .site-container { position:relative; z-index:1; max-width:860px; }

/* Pullquote sand */
.pq-sd { background:var(--sand); }
.pq-sd::before { color:rgba(30,21,6,.04); }
.pq-sd .pq-text { color:var(--ink); }
.pq-sd .pq-cite { color:var(--o); }

/* ── Services overview cards (icon style) ── */
.svc-card .svc-icon { font-size:20px; color:var(--o); display:block; margin-bottom:14px; }
.svc-card h3 { font-family:'Oswald',sans-serif; font-size:20px; font-weight:600; text-transform:uppercase; color:var(--ink); margin-bottom:10px; }
.svc-card h3 a { color:inherit; transition:color .2s; }
.svc-card h3 a:hover { color:var(--o); }
.svc-card > p { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:16px; font-weight:300; }
.svc-card .btn { padding:10px 22px; font-size:11px; }

/* ── Feature items (service sub-pages) ── */
.feat-item { background:var(--tan); padding:40px 36px; position:relative; overflow:hidden; transition:background .3s; }
.feat-item::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--o); transform:scaleX(0); transform-origin:left; transition:transform .35s; }
.feat-item:hover::before { transform:scaleX(1); }
.feat-item:hover { background:var(--cream); }
.feat-item h4 { font-family:'Oswald',sans-serif; font-size:20px; font-weight:600; text-transform:uppercase; color:var(--ink); margin-bottom:10px; }
.feat-item p { font-size:14px; color:var(--muted); line-height:1.7; font-weight:300; }

/* ── Gallery direct img ── */
.svc-gallery { overflow:hidden; }
.svc-gallery img { width:100%; height:320px; object-fit:cover; object-position:center center; display:block; transition:transform .7s cubic-bezier(.25,1,.5,1); }
.svc-gallery img:hover { transform:scale(1.04); }

/* ── Process body text ── */
.proc-body h4 { font-family:'Oswald',sans-serif; font-size:22px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--ink); margin-bottom:9px; }
.proc-body p { font-size:15px; color:var(--muted); line-height:1.7; font-weight:300; max-width:680px; }

/* ── Stats aliases ── */
.stat-num { display:block; font-family:'Oswald',sans-serif; font-size:clamp(48px,5vw,76px); font-weight:700; color:#fff; line-height:1; }
.stat-label { display:block; font-family:'Oswald',sans-serif; font-size:11px; font-weight:400; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:10px; }

/* ── About grid inner ── */
.ag-text { display:flex; flex-direction:column; }
.ag-img { position:relative; overflow:hidden; }
.ag-img img { width:100%; height:480px; object-fit:cover; display:block; }

/* ── Industry tile plain link ── */
.ind-tile > a { position:absolute; inset:0; display:flex; align-items:flex-end; padding:24px 20px; font-family:'Oswald',sans-serif; font-size:18px; font-weight:600; text-transform:uppercase; color:#fff; background:linear-gradient(to top,rgba(30,21,6,.88) 0%,transparent 65%); transition:color .2s; }
.ind-tile > a:hover { color:var(--o-lt); }

/* ── CTA aliases ── */
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:60px; flex-wrap:wrap; position:relative; z-index:2; }
.cta-title { font-family:'Oswald',sans-serif; font-size:clamp(30px,3.8vw,58px); font-weight:700; text-transform:uppercase; color:#fff; line-height:.92; letter-spacing:-1px; margin-bottom:12px; }
.cta-sub { font-size:17px; color:rgba(255,255,255,.78); font-weight:300; }

/* ── Footer aliases ── */
.footer-logo { height:56px; width:auto; margin-bottom:14px; }
.fg-head { font-family:'Oswald',sans-serif; font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.38); margin-bottom:18px; padding-bottom:10px; border-bottom:1px solid rgba(255,255,255,.1); display:block; }
.fg-list { display:flex; flex-direction:column; gap:10px; }
.fg-list a { font-size:13.5px; color:rgba(255,255,255,.55); transition:color .2s,padding-left .2s; font-weight:300; display:flex; align-items:center; gap:8px; }
.fg-list a::before { content:''; display:block; width:0; height:1px; background:var(--o); transition:width .25s; flex-shrink:0; }
.fg-list a:hover { color:var(--o); padding-left:4px; }
.fg-list a:hover::before { width:12px; }
.fg-addr { font-style:normal; font-size:13.5px; color:rgba(255,255,255,.55); line-height:1.8; font-weight:300; }
.fg-addr a { color:var(--o); }
.fg-addr a:hover { color:var(--o-lt); }
.fg-tagline { font-size:13.5px; color:rgba(255,255,255,.45); line-height:1.75; font-weight:300; margin-top:10px; }
.fg-hours { font-size:13px; color:rgba(255,255,255,.38); margin-top:12px; font-weight:300; }
.footer-bar { border-top:1px solid rgba(255,255,255,.09); padding:18px 0; }
.footer-bar p { font-size:12px; color:rgba(255,255,255,.3); font-weight:300; }

/* ── Contact page ── */
.ctc-val { font-size:14.5px; color:var(--ink); font-weight:300; line-height:1.5; }
.ctc-val a { color:var(--ink); transition:color .2s; }
.ctc-val a:hover { color:var(--o); }
.map-wrap { overflow:hidden; border:2px solid var(--sand); border-radius:4px; }
.contact-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:80px; align-items:start; }

/* ── Portfolio page overlays ── */
.mc-over { position:absolute; inset:0; background:rgba(224,123,0,.88); opacity:0; transition:opacity .35s; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:16px; text-align:center; }
.mc:hover .mc-over { opacity:1; }
.mc-cat { font-family:'Oswald',sans-serif; font-size:11px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.7); transform:translateY(12px); transition:transform .3s .1s; }
.mc:hover .mc-cat { transform:translateY(0); }
.mc-title { font-family:'Oswald',sans-serif; font-size:16px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:#fff; transform:translateY(12px); transition:transform .3s .05s; }
.mc:hover .mc-title { transform:translateY(0); }

/* ── FAQ accordion ── */
.faq-cat-title { font-family:'Oswald',sans-serif; font-size:22px; font-weight:600; text-transform:uppercase; color:var(--o); letter-spacing:1px; margin:48px 0 12px; padding-bottom:10px; border-bottom:2px solid var(--sand); }
.faq-list { display:flex; flex-direction:column; border:2px solid var(--sand); }
.faq-item { border-bottom:1px solid var(--sand); }
.faq-item:last-child { border-bottom:none; }
.faq-q { width:100%; text-align:left; background:none; border:none; padding:20px 28px; font-family:'Oswald',sans-serif; font-size:15px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--ink); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; transition:background .2s,color .2s; }
.faq-q:hover { background:var(--tan); color:var(--o); }
.faq-item.open .faq-q { background:var(--tan); color:var(--o); }
.faq-q-icon { font-size:24px; font-weight:300; color:var(--o); flex-shrink:0; transition:transform .3s; line-height:1; }
.faq-item.open .faq-q-icon { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.faq-item.open .faq-a { max-height:600px; }
.faq-a-inner { padding:4px 28px 24px; }
.faq-a p { font-size:15px; color:var(--muted); line-height:1.8; font-weight:300; margin-bottom:10px; }
.faq-a p:last-child { margin-bottom:0; }
.faq-a a { color:var(--o); }
.faq-a a:hover { color:var(--o-dk); }
.faq-a ul { list-style:none; display:flex; flex-direction:column; gap:7px; margin-top:10px; }
.faq-a ul li { font-size:14px; color:var(--muted); font-weight:300; display:flex; align-items:flex-start; gap:10px; }
.faq-a ul li::before { content:'→'; color:var(--o); flex-shrink:0; font-family:'Oswald',sans-serif; font-weight:600; }

/* ── Privacy / Prose ── */
.prose h2 { font-family:'Oswald',sans-serif; font-size:26px; font-weight:700; text-transform:uppercase; color:var(--ink); letter-spacing:-.5px; margin:44px 0 12px; padding-bottom:8px; border-bottom:2px solid var(--sand); }
.prose h2:first-child { margin-top:0; }
.prose h3 { font-family:'Oswald',sans-serif; font-size:17px; font-weight:600; text-transform:uppercase; color:var(--ink); margin:26px 0 8px; }
.prose p { font-size:15px; color:var(--muted); line-height:1.85; margin-bottom:14px; font-weight:300; }
.prose ul,.prose ol { margin:8px 0 16px 20px; display:flex; flex-direction:column; gap:7px; }
.prose ul li { font-size:14px; color:var(--muted); font-weight:300; list-style:disc; }
.prose ol li { font-size:14px; color:var(--muted); font-weight:300; list-style:decimal; }
.prose a { color:var(--o); text-decoration:underline; }
.prose a:hover { color:var(--o-dk); }
.prose strong { color:var(--ink); font-weight:700; }
.prose address { font-style:normal; }

/* ── Responsive additions ── */
@media (max-width:1200px) {
  .cblock .cb-text { padding:60px 48px; }
  .contact-grid { grid-template-columns:1fr; gap:48px; }
  .cta-inner { flex-direction:column; align-items:flex-start; }
  .ag-img img { height:380px; }
}
@media (max-width:980px) {
  .about-grid { grid-template-columns:1fr; gap:48px; }
  .ag-img img { height:320px; }
  .feat-grid { grid-template-columns:1fr; }
}
@media (max-width:767px) {
  .section-pad { padding:60px 0; }
  .cblock .cb-img { min-height:300px; }
  .cblock .cb-text { padding:48px 24px; }
  .faq-q { padding:16px 20px; }
  .faq-a-inner { padding:4px 20px 20px; }
  .cta-inner { gap:32px; }
}

/* ================================================================
   GOOGLE REVIEWS SECTION
   ================================================================ */
.reviews-header {
  display:flex;
  align-items:center;
  gap:28px;
  margin-bottom:52px;
  flex-wrap:wrap;
}
.grating {
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.grating-stars {
  font-size:28px;
  color:#fbbc04;
  letter-spacing:2px;
  line-height:1;
}
.grating-score {
  font-family:'Oswald',sans-serif;
  font-size:22px;
  font-weight:600;
  color:var(--ink);
}
.grating-label {
  font-size:13px;
  color:var(--o);
  font-weight:600;
}
.grating-link {
  font-family:'Oswald',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  text-decoration:none;
  border-bottom:1px solid currentColor;
  padding-bottom:1px;
  transition:color .2s;
}
.grating-link:hover { color:var(--o-dk); }
.reviews-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:0;
}
.review-card {
  background:#fff;
  border:1px solid var(--sand);
  border-radius:2px;
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:16px;
  box-shadow:0 2px 16px rgba(30,21,6,.06);
  transition:box-shadow .3s,transform .3s;
}
.review-card:hover {
  box-shadow:0 8px 40px rgba(30,21,6,.12);
  transform:translateY(-3px);
}
.rv-stars {
  font-size:18px;
  color:#fbbc04;
  letter-spacing:2px;
  line-height:1;
}
.rv-google {
  display:flex;
  align-items:center;
  gap:6px;
  margin-bottom:4px;
}
.rv-google-logo {
  font-family:'Oswald',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:1px;
  color:var(--o);
}
.rv-text {
  font-size:15px;
  color:var(--ink);
  line-height:1.75;
  font-weight:300;
  flex:1;
  font-style:italic;
}
.rv-author {
  display:flex;
  align-items:center;
  gap:14px;
  padding-top:12px;
  border-top:1px solid var(--sand);
  margin-top:auto;
}
.rv-initials {
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--o);
  color:#fff;
  font-family:'Oswald',sans-serif;
  font-size:17px;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.rv-name {
  font-family:'Oswald',sans-serif;
  font-size:14px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--ink);
}
.rv-via {
  font-size:12px;
  color:var(--o);
  font-weight:400;
  margin-top:2px;
}
.reviews-cta {
  text-align:center;
  margin-top:44px;
}
@media (max-width:900px) {
  .reviews-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .reviews-grid { grid-template-columns:1fr; }
  .grating { gap:12px; }
}

/* ================================================================
   WHY CHOOSE US SECTION
   ================================================================ */
.why-sec {
  background:var(--ink);
  position:relative;
  overflow:hidden;
}
.why-sec::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 80% 50%, rgba(224,123,0,.12) 0%, transparent 65%);
  pointer-events:none;
}
.why-sec .sec-title-wht { color:#fff; }
.why-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
  margin-top:52px;
  background:rgba(255,255,255,.06);
}
.why-card {
  background:rgba(255,255,255,.03);
  padding:44px 32px 40px;
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:background .3s;
}
.why-card:hover { background:rgba(224,123,0,.12); }
.why-num {
  font-family:'Oswald',sans-serif;
  font-size:68px;
  font-weight:700;
  color:var(--o);
  line-height:1;
  margin-bottom:4px;
}
.why-num sup { font-size:36px; vertical-align:super; }
.why-ttl {
  font-family:'Oswald',sans-serif;
  font-size:18px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:#fff;
}
.why-card > p {
  font-size:14px;
  color:rgba(255,255,255,.5);
  line-height:1.7;
  font-weight:300;
  flex:1;
}
.why-link {
  font-family:'Oswald',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--o);
  text-decoration:none;
  margin-top:4px;
  transition:color .2s;
}
.why-link:hover { color:var(--o-lt); }
@media (max-width:900px) { .why-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:560px) { .why-grid { grid-template-columns:1fr; } .why-num { font-size:52px; } }

/* ── Home page hero ink-stroke painting animation ── */
.hero-inkstroke {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 15;
  pointer-events: none;
}

@keyframes inkStroke {
  to { stroke-dashoffset: 0; }
}
