/* =========================================================
   STALLION — Page-builder section styles
   Layout modelled on the AirBrick reference; colours & motion
   stay with the Rayo design tokens (style.css).
   ========================================================= */

/* AirBrick-style clean canvas with the charcoal design tokens. */
:root{
  --bg:#ffffff;
  --base:#ffffff;
  --base-tint:#e8e8e8;
  --text-muted:#8a8a8a;
}
body{ background:var(--bg); overflow-x:hidden; }
/* responsive safety: media never overflows its container, no sideways scroll on phones */
img, svg, video, iframe{ max-width:100%; }
/* fluid side gutters across every breakpoint (overrides the fixed 3rem / 0 padding) */
.mxd-container{ padding:0 clamp(18px, 4vw, 48px); }

/* Fixed navbar overlays a hero/banner; otherwise content clears the navbar. */
#mxd-page-content{ padding-top: var(--nav-h, 74px); }
#mxd-page-content.has-hero{ padding-top: 0; }

/* Centered content width (AirBrick feel); hero/banner stay full-bleed. */
.sec .mxd-container{ max-width:1500px; margin-inline:auto; }

.sec { padding: clamp(44px, 6vw, 96px) 0; }
.sec--tight { padding: clamp(28px, 3.5vw, 56px) 0; }

/* Big AirBrick heading with a full-width rule underneath. */
.sec-head { margin-bottom: 40px; }
.sec-head.center { text-align: center; }
.sec-head.center .sec-title::after { margin-left:auto; margin-right:auto; }
.sec-eyebrow { display:inline-block; font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  color: var(--accent); font-weight:700; margin-bottom:12px; }
.sec-title { font-size: clamp(34px, 5vw, 66px); line-height:1.02; letter-spacing:-.025em; font-weight:700;
  padding-bottom:18px; position:relative; }
.sec-title::after { content:""; display:block; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:var(--base-tint); }
.sec-title.h3 { font-size: clamp(22px, 2.6vw, 34px); padding-bottom:0; }
.sec-title.h3::after { display:none; }
.sec-sub { font-size: clamp(16px, 1.3vw, 20px); color: var(--text-bright); margin-top:18px; line-height:1.6; font-weight:500; }
.text-center { text-align:center; }
.text-right { text-align:right; }

.lead { font-size: clamp(17px,1.5vw,22px); line-height:1.6; color:var(--text-bright); max-width:860px; }
.prose { max-width: 860px; font-size:17px; line-height:1.75; color:var(--text-bright); }
.prose p { margin-bottom: 1em; }

/* Bullets / numbered */
.bullet-list, .numbered-list { max-width: 860px; }
.bullet-list li, .numbered-list li { position:relative; padding:12px 0 12px 38px; border-bottom:1px solid var(--base-tint);
  font-size:18px; color:var(--text-bright); }
.bullet-list li::before { content:"✦"; position:absolute; left:4px; color:var(--accent); }
.numbered-list { counter-reset: n; }
.numbered-list li { counter-increment: n; }
.numbered-list li::before { content: counter(n,decimal-leading-zero); position:absolute; left:0; color:var(--accent); font-weight:700; }

/* Quote */
.quote-block { max-width: 920px; border-left:4px solid var(--accent); padding:8px 0 8px 32px; }
.quote-block p { font-size: clamp(22px,2.4vw,34px); line-height:1.35; font-weight:500; letter-spacing:-.01em; }
.quote-cite { margin-top:18px; color:var(--text-muted); font-size:15px; }

/* ===== Hero slider — cinematic premium banner ===== */
.hero-section { margin-top:0; }
.hero-slider { position:relative; overflow:hidden; min-height:clamp(640px,100vh,1080px); background:#0f0f0f; }
.hero-track { position:absolute; inset:0; }
.hero-slide { position:absolute; inset:0; display:flex; align-items:flex-end;
  opacity:0; visibility:hidden; z-index:1; transition:opacity 1.1s ease, visibility 1.1s ease; }
.hero-slide.is-active { opacity:1; visibility:visible; z-index:2; }
.hero-slide__bg { position:absolute; inset:0; overflow:hidden; }
.hero-slide__bg img, .hero-slide__bg video { width:100%; height:100%; object-fit:cover;
  transform:scale(1.14); transition:transform 9s ease-out; will-change:transform; }
.hero-slide.is-active .hero-slide__bg img,
.hero-slide.is-active .hero-slide__bg video { transform:scale(1); }
/* cinematic scrim + charcoal vignette for legibility + brand */
.hero-slide::after { content:""; position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(10,10,10,.32) 0%, rgba(10,10,10,.08) 34%, rgba(10,10,10,.86) 100%),
    radial-gradient(130% 80% at 16% 86%, rgba(46, 46, 46,.34), transparent 58%); }
.hero-slide__inner { position:relative; z-index:2; width:100%; max-width:1500px; margin:0 auto;
  padding: clamp(40px,7vw,120px) clamp(20px,3vw,46px) clamp(104px,9vw,160px); color:#fff; }
.hero-slide__content { max-width:920px; }
.hero-slide__caption { display:inline-flex; align-items:center; gap:14px; letter-spacing:.2em;
  text-transform:uppercase; font-size:13px; font-weight:700; color:#fff; margin-bottom:22px; }
.hero-slide__caption::before { content:""; width:40px; height:2px; background:var(--accent-glow,#9a9a9a); display:inline-block; }
.hero-slide__title { font-size: clamp(40px,7.4vw,108px); line-height:1.02; letter-spacing:-.03em; color:#fff; max-width:15ch; font-weight:700; }
.hero-slide__desc { margin-top:22px; font-size: clamp(16px,1.4vw,21px); max-width:620px; opacity:.92; line-height:1.6; }
.hero-slide__cta { margin-top:34px; display:flex; gap:14px; flex-wrap:wrap; }
/* staggered text reveal each time a slide becomes active */
.hero-slide__content > * { opacity:0; transform:translateY(36px); }
.hero-slide.is-active .hero-slide__content > * { animation:heroReveal .95s cubic-bezier(.16,1,.3,1) both; }
.hero-slide.is-active .hero-slide__caption { animation-delay:.25s; }
.hero-slide.is-active .hero-slide__title   { animation-delay:.40s; }
.hero-slide.is-active .hero-slide__desc    { animation-delay:.55s; }
.hero-slide.is-active .hero-slide__cta     { animation-delay:.70s; }
@keyframes heroReveal { from{opacity:0;transform:translateY(36px)} to{opacity:1;transform:none} }

.btn-outline-light { border:1px solid rgba(255,255,255,.6); color:#fff; background:transparent; }
.btn-outline-light:hover { background:#fff; color:#0d0d0d; }

/* ----- Hero UI: arrows, counter, progress bar, dots ----- */
.hero-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:4;
  width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.28); color:#fff; cursor:pointer;
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); transition:.3s; }
.hero-arrow:hover { background:var(--accent,#2e2e2e); border-color:var(--accent,#2e2e2e); transform:translateY(-50%) scale(1.08); }
.hero-arrow--prev { left:clamp(12px,2vw,30px); }
.hero-arrow--next { right:clamp(12px,2vw,30px); }

.hero-bottom { position:absolute; z-index:4; left:0; right:0; bottom:clamp(26px,4vw,46px);
  max-width:1500px; margin:0 auto; padding:0 clamp(20px,3vw,46px); display:flex; align-items:center; gap:22px; }
.hero-count { color:#fff; font-weight:600; font-size:14px; letter-spacing:.06em; font-variant-numeric:tabular-nums; }
.hero-count b { font-size:21px; margin-right:4px; }
.hero-count span { opacity:.55; }
.hero-progress { position:relative; flex:1; height:3px; max-width:260px; background:rgba(255,255,255,.18); border-radius:3px; overflow:hidden; }
.hero-progress__bar { position:absolute; inset:0; transform-origin:left; transform:scaleX(0);
  background:linear-gradient(90deg,var(--accent,#2e2e2e),var(--accent-glow,#9a9a9a)); }
.hero-progress__bar.run { animation:heroBar var(--hero-dur,6s) linear forwards; }
@keyframes heroBar { from{transform:scaleX(0)} to{transform:scaleX(1)} }
.hero-dots { display:flex; gap:10px; margin-left:auto; }
.hero-dots button { width:12px; height:12px; padding:0; border-radius:50%; background:rgba(255,255,255,.4);
  border:none; cursor:pointer; transition:.3s; }
.hero-dots button:hover { background:rgba(255,255,255,.8); }
.hero-dots button.active { background:var(--accent-glow,#9a9a9a); width:34px; border-radius:7px; }

@media(max-width:768px){
  .hero-arrow { display:none; }
  .hero-progress { display:none; }
}
@media(prefers-reduced-motion:reduce){
  .hero-slide__bg img, .hero-slide__bg video { transition:none; transform:none; }
  .hero-slide.is-active .hero-slide__content > * { animation:none; opacity:1; transform:none; }
  .hero-progress__bar.run { animation:none; }
}

/* ===== Service detail — premium hero ===== */
.service-hero { position:relative; min-height:clamp(440px,64vh,660px); display:flex; align-items:flex-end; overflow:hidden; background:#0f0f0f; }
.service-hero__bg { position:absolute; inset:0; }
.service-hero__bg img { width:100%; height:100%; object-fit:cover; transform:scale(1.06); animation:svcHeroZoom 12s ease-out forwards; }
@keyframes svcHeroZoom { to { transform:scale(1); } }
.service-hero::after { content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(10,10,10,.46) 0%, rgba(10,10,10,.18) 36%, rgba(10,10,10,.9) 100%),
    radial-gradient(130% 80% at 16% 88%, rgba(46, 46, 46,.4), transparent 60%); }
.service-hero__inner { position:relative; z-index:2; width:100%; max-width:1500px; margin:0 auto; color:#fff;
  padding:clamp(118px,16vh,180px) clamp(20px,3vw,46px) clamp(46px,6vw,82px); }
.service-hero__crumbs { display:flex; align-items:center; gap:10px; font-size:13px; color:rgba(255,255,255,.7); margin-bottom:18px; flex-wrap:wrap; }
.service-hero__crumbs a { color:rgba(255,255,255,.7); }
.service-hero__crumbs a:hover { color:#fff; }
.service-hero__crumbs .cur { color:var(--accent-glow,#9a9a9a); }
.service-hero__eyebrow { display:inline-flex; align-items:center; gap:12px; letter-spacing:.2em; text-transform:uppercase;
  font-size:13px; font-weight:700; color:var(--accent-glow,#9a9a9a); margin-bottom:16px; }
.service-hero__eyebrow::before { content:""; width:34px; height:2px; background:var(--accent-glow,#9a9a9a); }
.service-hero__title { font-size:clamp(38px,6vw,84px); line-height:1.03; letter-spacing:-.03em; font-weight:700; color:#fff; max-width:16ch; }
.service-hero__sub { margin-top:20px; font-size:clamp(16px,1.4vw,20px); line-height:1.6; max-width:640px; color:rgba(255,255,255,.9); }
.service-hero__tags { display:flex; gap:8px; flex-wrap:wrap; margin-top:22px; }
.service-hero__tags .tag { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:#fff;
  padding:6px 14px; border-radius:50px; font-size:13px; backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); }
.service-hero__cta { display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
@media(max-width:600px){ .service-hero__cta .btn { flex:1 1 auto; justify-content:center; } }

/* Inner-page image banner (about/services/careers/etc.) */
.page-banner { position:relative; height:clamp(300px,46vh,480px); margin-top:0; overflow:hidden; }
.page-banner img { width:100%; height:100%; object-fit:cover; }
.page-banner::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(13,13,13,.45),rgba(13,13,13,.25)); }
.page-banner__title { position:absolute; z-index:2; left:0; right:0; bottom:0; max-width:1500px; margin:0 auto;
  padding:0 clamp(20px,3vw,46px) clamp(28px,4vw,56px); color:#fff; }
.page-banner__title h1 { font-size:clamp(34px,5.5vw,72px); font-weight:700; letter-spacing:-.02em; color:#fff; }

/* About */
.about-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,64px); align-items:center; }
.about-media { position:relative; border-radius: var(--radius-m); overflow:hidden; }
.about-media img { width:100%; height:100%; object-fit:cover; aspect-ratio: 4/3.4; }
.about-counter { position:absolute; left:22px; bottom:22px; background:var(--accent); color:#fff;
  border-radius:var(--radius-s); padding:18px 22px; }
.about-counter .num { font-size:40px; font-weight:700; line-height:1; }
.about-counter .lbl { font-size:13px; opacity:.92; margin-top:6px; }

/* Generic card grid */
.card-grid { display:grid; gap:22px; }
.cols-2 { grid-template-columns: repeat(2,1fr); }
.cols-3 { grid-template-columns: repeat(3,1fr); }
.cols-4 { grid-template-columns: repeat(4,1fr); }

.feature-card, .why-card, .service-card { background:var(--base); border:1px solid var(--base-tint);
  border-radius: var(--radius-m); padding: 30px; transition: var(--transition); }
.feature-card:hover, .why-card:hover, .service-card:hover { transform: translateY(-6px); box-shadow:0 22px 50px rgba(0,0,0,.08); }
.card-ico { width:56px; height:56px; border-radius:14px; background:var(--base-tint); display:flex;
  align-items:center; justify-content:center; font-size:24px; margin-bottom:20px; }
.service-card .card-ico { background: var(--additional); }
.card-title { font-size:22px; margin-bottom:10px; }
.card-text { color:var(--text-muted); line-height:1.6; }
.service-card__img { border-radius: var(--radius-s); overflow:hidden; margin-bottom:20px; aspect-ratio:16/10; }
.service-card__img img { width:100%; height:100%; object-fit:cover; }
.card-link { display:inline-flex; gap:6px; margin-top:18px; font-weight:600; color:var(--accent); }

/* Projects */
.project-card { position:relative; border-radius:var(--radius-m); overflow:hidden; aspect-ratio:4/3; display:block; }
.project-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.project-card:hover img { transform:scale(1.06); }
.project-card__meta { position:absolute; inset:auto 0 0 0; padding:24px;
  background:linear-gradient(180deg,transparent,rgba(13,13,13,.78)); color:#fff; }
.project-card__meta h3 { font-size:22px; }
.project-card__meta span { font-size:13px; opacity:.85; }

/* Team */
.team-card { text-align:center; }
.team-card__img { border-radius:var(--radius-m); overflow:hidden; aspect-ratio:3/3.4; margin-bottom:18px; background:var(--base-tint); }
.team-card__img img { width:100%; height:100%; object-fit:cover; }
.team-card h3 { font-size:20px; }
.team-card .role { color:var(--text-muted); font-size:14px; margin-top:4px; }
.team-card .socials { display:flex; gap:12px; justify-content:center; margin-top:12px; }
.team-card .socials a { color:var(--text-muted); }

/* ===== Testimonials — professional review cards ===== */
.testi-card { position:relative; overflow:hidden; display:flex; flex-direction:column; height:100%;
  background:#fff; border:1px solid var(--base-tint); border-radius:22px; padding:34px 32px 30px;
  transition:transform .45s cubic-bezier(.16,1,.3,1), box-shadow .45s ease, border-color .45s ease; }
/* accent bar that wipes in on hover */
.testi-card::before { content:""; position:absolute; left:0; top:0; width:100%; height:4px; transform:scaleX(0);
  transform-origin:left; background:linear-gradient(90deg,var(--accent,#2e2e2e),var(--accent-glow,#9a9a9a));
  transition:transform .45s cubic-bezier(.16,1,.3,1); }
.testi-card:hover { transform:translateY(-8px); box-shadow:0 26px 56px rgba(17, 17, 17,.12); border-color:rgba(46, 46, 46,.3); }
.testi-card:hover::before { transform:scaleX(1); }
/* large decorative quote glyph */
.testi-quote { position:absolute; right:26px; top:22px; font-size:46px; line-height:1; opacity:.16;
  background:linear-gradient(135deg,var(--accent,#2e2e2e),var(--accent-glow,#9a9a9a));
  -webkit-background-clip:text; background-clip:text; color:transparent; transition:opacity .4s ease; }
.testi-card:hover .testi-quote { opacity:.32; }
.testi-stars { display:flex; gap:3px; color:#f6b73c; font-size:14px; margin-bottom:16px; }
.testi-stars .off { color:#d9d9d9; }
.testi-text { position:relative; z-index:1; flex:1; font-size:17px; line-height:1.65; color:var(--text-bright); }
.testi-author { display:flex; align-items:center; gap:14px; margin-top:24px; padding-top:22px; border-top:1px solid var(--base-tint); }
.testi-avatar { flex:0 0 auto; width:54px; height:54px; border-radius:50%; padding:2px; display:block;
  background:linear-gradient(135deg,var(--accent,#2e2e2e),var(--accent-glow,#9a9a9a)); }
.testi-avatar img { width:100%; height:100%; border-radius:50%; object-fit:cover; border:2px solid #fff; display:block; }
.testi-author .nm { font-weight:700; color:var(--accent-deep,#111111); }
.testi-author .dg { font-size:13px; color:var(--text-muted); margin-top:1px; }

/* ===== Why Choose Stallion — staggered photo process cards ===== */
.ww-process { position:relative; z-index:1; }
.ww-list { display:flex; flex-wrap:wrap; margin:0 -14px; }
.ww-item { flex:0 0 25%; max-width:25%; padding:0 14px; }
.ww-item:nth-child(1) { margin-top:180px; }
.ww-item:nth-child(2) { margin-top:120px; }
.ww-item:nth-child(3) { margin-top:60px; }
.ww-item:nth-child(4) { margin-top:0; }
.ww-content { position:relative; z-index:1; overflow:hidden; border-radius:18px;
  padding:108px 26px 28px; background-position:center; background-size:cover; background-repeat:no-repeat;
  box-shadow:0 14px 36px rgba(17, 17, 17,.10); }
/* default solid tint hides the photo */
.ww-content::before { content:""; position:absolute; inset:0; z-index:-1; background:#efefef; transition:.5s ease; }
/* charcoal overlay revealed over the photo on hover */
.ww-content::after { content:""; position:absolute; inset:0; z-index:-1; opacity:0; visibility:hidden; transition:.5s ease;
  background:linear-gradient(160deg, rgba(22, 22, 22,.55), rgba(46, 46, 46,.78)); }
.ww-content:hover::before { opacity:0; visibility:hidden; }
.ww-content:hover::after { opacity:1; visibility:visible; }
.ww-content:hover { box-shadow:0 26px 52px rgba(17, 17, 17,.18); }
.ww-num { position:absolute; left:0; top:0; width:78px; height:78px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--accent,#2e2e2e),var(--accent-glow,#9a9a9a)); color:#fff;
  font-size:42px; font-weight:800; line-height:1; border-bottom-right-radius:18px;
  box-shadow:0 10px 22px rgba(46, 46, 46,.34); }
.ww-content h3 { margin:0; font-size:22px; font-weight:700; color:var(--accent-deep,#111111); transition:color .5s ease; }
.ww-content p { margin:10px 0 0; line-height:1.7; color:var(--text-bright,#2a2a2a); transition:color .5s ease; }
.ww-content:hover h3, .ww-content:hover p { color:#fff; }

@media (max-width:991px){
  .ww-item { flex:0 0 50%; max-width:50%; }
  .ww-item:nth-child(1), .ww-item:nth-child(2),
  .ww-item:nth-child(3), .ww-item:nth-child(4) { margin-top:0; margin-bottom:28px; }
}
@media (max-width:575px){
  .ww-item { flex:0 0 100%; max-width:100%; }
  .ww-num { width:62px; height:62px; font-size:34px; }
  .ww-content { padding-top:92px; }
}

/* ===== Clients — dual-row animated premium logo wall ===== */
.clients-sec { position:relative; overflow:hidden; }
/* soft accent glow behind the section */
.clients-sec::before { content:""; position:absolute; left:50%; top:46%; width:720px; height:720px;
  transform:translate(-50%,-50%); border-radius:50%; z-index:0; pointer-events:none; opacity:.55;
  background:radial-gradient(circle, var(--accent-soft,#ededed), transparent 66%); }
.clients-sec > * { position:relative; z-index:1; }

.client-marquee { position:relative; margin-top:38px; display:flex; flex-direction:column; gap:24px;
  -webkit-mask:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.client-row { overflow:hidden; }
.client-track { display:flex; gap:26px; width:max-content; padding:8px 0;
  animation:clientScroll 42s linear infinite; }
.client-track--rev { animation-direction:reverse; animation-duration:50s; }
.client-marquee:hover .client-track { animation-play-state:paused; }
@keyframes clientScroll { from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

.client-chip { position:relative; isolation:isolate; flex:0 0 auto; width:224px; height:122px;
  display:flex; align-items:center; justify-content:center; gap:13px; padding:0 26px;
  background:#fff; border-radius:22px; box-shadow:0 12px 30px rgba(17, 17, 17,.07); overflow:hidden;
  transition:transform .5s cubic-bezier(.16,1,.3,1), box-shadow .5s ease; }
/* gradient ring border (brightens to accent on hover) */
.client-chip::before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1.5px; z-index:0;
  background:linear-gradient(135deg, rgba(46, 46, 46,.28), rgba(154, 154, 154,.06) 45%, rgba(46, 46, 46,.28));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; transition:background .45s ease, opacity .45s ease; }
/* diagonal light sheen that sweeps across on hover */
.client-chip::after { content:""; position:absolute; top:0; left:-130%; width:55%; height:100%; z-index:0;
  transform:skewX(-20deg); pointer-events:none;
  background:linear-gradient(120deg, transparent, rgba(46, 46, 46,.16), transparent); transition:left .75s ease; }
.client-chip:hover { transform:translateY(-9px) scale(1.025); box-shadow:0 28px 52px rgba(46, 46, 46,.20); }
.client-chip:hover::before { background:linear-gradient(135deg, var(--accent,#2e2e2e), var(--accent-glow,#9a9a9a)); }
.client-chip:hover::after { left:135%; }

/* logo image (uploaded or brand URL) — full colour, no grayscale */
.client-chip__img { position:relative; z-index:1; max-height:60px; max-width:152px; object-fit:contain;
  transition:transform .5s cubic-bezier(.16,1,.3,1); }
.client-chip:hover .client-chip__img { transform:scale(1.08); }
/* when a real logo is shown, hide the monogram fallback */
.client-chip.has-logo .client-chip__mark,
.client-chip.has-logo .client-chip__name { display:none; }

/* generated brand lockup (monogram mark + wordmark) */
.client-chip__mark { position:relative; z-index:1; flex:0 0 auto; width:44px; height:44px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-weight:800; font-size:16px; color:#fff;
  background:linear-gradient(135deg, var(--accent,#2e2e2e), var(--accent-glow,#9a9a9a));
  box-shadow:0 6px 16px rgba(46, 46, 46,.35); transition:transform .5s cubic-bezier(.16,1,.3,1); }
.client-chip:hover .client-chip__mark { transform:rotate(-6deg) scale(1.08); }
.client-chip__name { position:relative; z-index:1; font-weight:800; font-size:18px; letter-spacing:.01em;
  color:var(--accent-deep,#111111); white-space:nowrap; transition:color .35s ease; }
.client-chip:hover .client-chip__name { color:var(--accent,#2e2e2e); }

@media(prefers-reduced-motion:reduce){
  .client-track { animation:none; flex-wrap:wrap; justify-content:center; width:auto; }
  .client-marquee { mask:none; -webkit-mask:none; }
}

/* Media */
.single-image figure { border-radius:var(--radius-m); overflow:hidden; }
.single-image img { width:100%; }
.single-image figcaption { color:var(--text-muted); font-size:14px; margin-top:12px; text-align:center; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery-grid a { border-radius:var(--radius-s); overflow:hidden; aspect-ratio:4/3; }
.gallery-grid img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-grid a:hover img { transform:scale(1.07); }

/* ===== Project Gallery — diamond tessellation (big images) ===== */
.gallery-sec .sec-head { margin-bottom:44px; }
.diamond-gallery {
  --gap:0.5rem;
  --image-size: clamp(56px, 13vw, 190px);
  display:grid;
  grid-template-columns:repeat(6, var(--image-size));
  grid-auto-rows:var(--image-size);
  gap:var(--gap);
  justify-content:center;
  padding-bottom:var(--image-size);   /* room for the overlapping last row */
  transition:transform .4s ease;
}
.diamond-gallery:hover { transform:scale(.99); }
.diamond-gallery:hover img { filter:brightness(.5) saturate(.6); }
.diamond-gallery img {
  width:100%; aspect-ratio:1; object-fit:cover; align-self:start;
  grid-column:span 2; cursor:pointer;
  clip-path:polygon(50% 1%, 99% 50%, 50% 99%, 1% 50%);
  transition:clip-path .3s ease, transform .8s cubic-bezier(.16,1,.3,1), filter .5s ease, border-radius .3s ease;
}
.diamond-gallery img:nth-of-type(4) { grid-column:2 / span 2; }
.diamond-gallery img:hover {
  clip-path:polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transform:scale(1.35);
  z-index:100;
  filter:brightness(1.05) saturate(1.2);
  border-radius:10px;
  box-shadow:0 26px 54px rgba(17, 17, 17,.32);
}
.diamond-gallery img:not(:hover) { animation:diamondZ .5s; }
@keyframes diamondZ { 0%,100%{ z-index:1; } }
@media (prefers-reduced-motion:reduce){
  .diamond-gallery, .diamond-gallery:hover, .diamond-gallery img, .diamond-gallery:hover img { transition:none; transform:none; filter:none; }
}
/* phones: drop the diamond tessellation for a clean, tappable 2-up grid */
@media (max-width:600px){
  .diamond-gallery { grid-template-columns:repeat(2,1fr); grid-auto-rows:auto; gap:10px; padding-bottom:0; }
  .diamond-gallery img { grid-column:auto !important; aspect-ratio:1; align-self:stretch;
    clip-path:none; border-radius:12px; }
  .diamond-gallery:hover { transform:none; }
  .diamond-gallery:hover img { filter:none; }
  .diamond-gallery img:hover { transform:none; clip-path:none; box-shadow:0 12px 26px rgba(17, 17, 17,.18); }
}
.video-wrap { position:relative; border-radius:var(--radius-m); overflow:hidden; aspect-ratio:16/9; background:#000; }
.video-wrap iframe, .video-wrap video { width:100%; height:100%; border:0; object-fit:cover; }

/* Cinematic disguised embed — crop player chrome/branding, block hover UI */
.video-wrap--cinema .video-bg { position:absolute; top:50%; left:50%; width:100%; height:100%;
  transform:translate(-50%,-50%) scale(1.34); pointer-events:none; }
.video-shield { position:absolute; inset:0; z-index:2; background:transparent; border:none; cursor:pointer; padding:0; }
.video-sound { position:absolute; right:16px; bottom:16px; z-index:3; width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; pointer-events:none; color:#fff; font-size:15px;
  background:rgba(0,0,0,.5); backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); transition:background .3s ease; }
.video-wrap--cinema:hover .video-sound { background:var(--accent,#2e2e2e); }

/* Stats — AirBrick "100+ / 500K+" row */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.stat-item .num { font-size: clamp(46px,6vw,84px); font-weight:700; letter-spacing:-.03em; color:var(--accent);
  line-height:1; }
.stat-item .lbl { color:var(--text-bright); margin-top:12px; font-weight:600; font-size:15px; }

/* Timeline */
.timeline { position:relative; max-width:880px; margin:0 auto; }
.timeline::before { content:""; position:absolute; left:14px; top:0; bottom:0; width:2px; background:var(--base-tint); }
.tl-item { position:relative; padding:0 0 38px 52px; }
.tl-item::before { content:""; position:absolute; left:7px; top:4px; width:16px; height:16px; border-radius:50%;
  background:var(--accent); border:3px solid var(--bg); }
.tl-item .year { color:var(--accent); font-weight:700; }
.tl-item h3 { font-size:22px; margin:4px 0 8px; }
.tl-item p { color:var(--text-muted); line-height:1.6; }

/* Pricing */
.price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.price-card { background:var(--base); border:1px solid var(--base-tint); border-radius:var(--radius-m); padding:34px; }
.price-card.featured { background:var(--base-opp); color:var(--text-opposite); border-color:var(--base-opp); }
.price-card.featured .price-amt, .price-card.featured h3 { color:var(--text-opposite); }
.price-amt { font-size:44px; font-weight:700; margin:12px 0; }
.price-amt span { font-size:16px; color:var(--text-muted); font-weight:400; }
.price-feats { margin:20px 0; }
.price-feats li { padding:9px 0; border-bottom:1px solid var(--base-tint); }
.price-card.featured .price-feats li { border-color:rgba(255,255,255,.14); }

/* Accordion / FAQ / Tabs */
.acc-item, .faq-item { border-bottom:1px solid var(--base-tint); }
.acc-q, .faq-q { width:100%; text-align:left; display:flex; justify-content:space-between; gap:16px; align-items:center;
  padding:22px 0; font-size:19px; font-weight:600; cursor:pointer; }
.acc-q::after, .faq-q::after { content:"+"; font-size:24px; color:var(--accent); transition:var(--transition); }
.acc-item.open .acc-q::after, .faq-item.open .faq-q::after { transform:rotate(45deg); }
.acc-a, .faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease; color:var(--text-muted); line-height:1.7; }
.acc-item.open .acc-a, .faq-item.open .faq-a { max-height:600px; padding-bottom:22px; }
.acc-wrap, .faq-wrap { max-width:880px; }

.tabs-nav { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; }
.tabs-nav button { padding:12px 22px; border-radius:50px; border:1px solid var(--base-tint); background:var(--base);
  font:inherit; font-weight:600; cursor:pointer; transition:var(--transition); }
.tabs-nav button.active { background:var(--accent); color:#fff; border-color:var(--accent); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }
.tab-panel__grid { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; }
.tab-panel__grid img { width:100%; border-radius:var(--radius-m); }

/* Contact form */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.form-card { background:var(--base); border:1px solid var(--base-tint); border-radius:var(--radius-m); padding:34px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-row { margin-bottom:16px; }
.field-row label { display:block; font-size:13px; color:var(--text-muted); margin-bottom:7px; }
.field-row input, .field-row textarea, .field-row select { width:100%; padding:14px 16px; border:1px solid var(--base-tint);
  border-radius:var(--radius-s); background:var(--bg); font:inherit; font-size:15px; color:var(--text); }
.field-row textarea { min-height:120px; resize:vertical; }
.form-ok { background:var(--additional); color:#0d0d0d; padding:12px 16px; border-radius:var(--radius-s); margin-bottom:18px; }

/* ===== Get in Touch — premium two-column contact ===== */
.gt-grid { display:grid; grid-template-columns:1.05fr 1fr; gap:30px; align-items:stretch; }

/* left: gradient info panel */
.gt-info { position:relative; overflow:hidden; border-radius:26px; color:#fff;
  padding:clamp(28px,3.5vw,52px);
  background:linear-gradient(150deg,#161616 0%,#3a3a3a 55%,#2e2e2e 125%); }
.gt-info::before { content:""; position:absolute; width:440px; height:440px; right:-130px; top:-160px; border-radius:50%;
  background:radial-gradient(circle, rgba(154, 154, 154,.42), transparent 62%); pointer-events:none;
  animation:gtFloat 9s ease-in-out infinite; }
.gt-info::after { content:""; position:absolute; width:300px; height:300px; left:-120px; bottom:-140px; border-radius:50%;
  background:radial-gradient(circle, rgba(154, 154, 154,.22), transparent 66%); pointer-events:none; }
.gt-info > * { position:relative; z-index:1; }
@keyframes gtFloat { 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(-14px,16px); } }
.gt-eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:13px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent-glow,#9a9a9a); }
.gt-eyebrow::before { content:""; width:30px; height:2px; background:var(--accent-glow,#9a9a9a); }
.gt-title { font-size:clamp(28px,3.2vw,46px); line-height:1.08; letter-spacing:-.02em; font-weight:700; color:#fff; margin:14px 0 14px; }
.gt-sub { color:rgba(255,255,255,.82); line-height:1.7; max-width:46ch; }

.gt-contacts { list-style:none; margin-top:32px; display:flex; flex-direction:column; gap:16px; }
.gt-contact { display:flex; align-items:center; gap:16px; }
.gt-contact__ico { flex:0 0 auto; width:50px; height:50px; border-radius:14px; display:flex; align-items:center;
  justify-content:center; font-size:18px; color:var(--accent-glow,#9a9a9a);
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  transition:transform .35s cubic-bezier(.16,1,.3,1), background .35s ease, color .35s ease; }
.gt-contact:hover .gt-contact__ico { background:var(--accent-glow,#9a9a9a); color:#141414; transform:translateY(-4px) rotate(-6deg); }
.gt-contact small { display:block; font-size:11.5px; text-transform:uppercase; letter-spacing:.12em;
  color:rgba(255,255,255,.6); margin-bottom:3px; }
.gt-contact a, .gt-contact .val { color:#fff; font-weight:600; font-size:15.5px; line-height:1.4; }
.gt-contact a:hover { color:var(--accent-glow,#9a9a9a); }

.gt-socials { display:flex; gap:10px; margin-top:30px; }
.gt-socials a { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:#fff; background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  transition:transform .3s ease, background .3s ease, color .3s ease; }
.gt-socials a:hover { background:#fff; color:var(--accent,#2e2e2e); transform:translateY(-4px); }

.gt-map { margin-top:28px; border-radius:16px; overflow:hidden; aspect-ratio:16/9; border:1px solid rgba(255,255,255,.16); }
.gt-map iframe { width:100%; height:100%; border:0; }

/* right: form card */
.gt-form-card { background:#fff; border:1px solid var(--base-tint); border-radius:26px;
  padding:clamp(26px,3vw,42px); box-shadow:0 24px 60px rgba(17, 17, 17,.09); align-self:start; }
.gt-form-card h3 { font-size:23px; font-weight:700; color:var(--accent-deep,#111111); margin-bottom:6px; }
.gt-form-hint { color:var(--text-muted); font-size:14.5px; margin-bottom:24px; }
.gt-form-card .field-row input, .gt-form-card .field-row textarea {
  background:var(--base,#f7f7f7); border-radius:12px; transition:border-color .3s ease, box-shadow .3s ease, background .3s ease; }
.gt-form-card .field-row input:focus, .gt-form-card .field-row textarea:focus { background:#fff; }
.gt-submit { width:100%; justify-content:center; margin-top:8px; }
.gt-submit i { transition:transform .3s ease; }
.gt-submit:hover i { transform:translateX(4px); }

@media (max-width: 900px) {
  .gt-grid { grid-template-columns:1fr; }
}

/* Newsletter / CTA banner */
.nl-band, .cta-band { background:var(--base-opp); color:var(--text-opposite); border-radius:var(--radius-l);
  padding: clamp(36px,5vw,72px); text-align:center; }
.nl-band h2, .cta-band h2 { color:var(--text-opposite); font-size:clamp(28px,3.6vw,48px); }
.nl-band p, .cta-band p { color:rgba(255,255,255,.78); margin-top:12px; }
.nl-form { display:flex; gap:10px; max-width:520px; margin:26px auto 0; }
.nl-form input { flex:1; padding:15px 18px; border-radius:50px; border:none; font:inherit; }
.cta-band .btn { margin-top:26px; }

@media (max-width: 900px) {
  .about-grid, .contact-grid, .tab-panel__grid { grid-template-columns:1fr; }
  .cols-3, .cols-4, .stats-grid, .price-grid, .client-grid { grid-template-columns:repeat(2,1fr); }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 560px) {
  .cols-2, .cols-3, .cols-4, .stats-grid, .price-grid, .client-grid, .gallery-grid, .form-row { grid-template-columns:1fr; }
}

/* =========================================================
   charcoal + MODERN UPGRADE  (loaded last → wins)
   Elevated details over the AirBrick reference.
   ========================================================= */

/* Section eyebrow gets a small leading tick line */
.sec-eyebrow{ display:inline-flex; align-items:center; gap:10px; color:var(--accent); }
.sec-eyebrow::before{ content:""; width:26px; height:2px; border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-glow)); }
.sec-head.center .sec-eyebrow{ justify-content:center; }

/* Animated gradient stat numbers (AirBrick "100+ / 500K+") */
.stat-item .num{
  background:linear-gradient(135deg,var(--accent-deep) 0%,var(--accent) 45%,var(--accent-glow) 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.stat-item{ position:relative; padding:14px 8px; transition:var(--transition); }
.stat-item .lbl{ color:var(--text-bright); }

/* Cards — charcoal lift + ring on hover */
.feature-card:hover, .why-card:hover, .service-card:hover{
  transform:translateY(-8px);
  box-shadow:0 26px 56px rgba(17, 17, 17,.14);
  border-color:rgba(46, 46, 46,.35);
}
.card-ico{ background:var(--accent-soft); color:var(--accent); transition:var(--transition); }
.feature-card:hover .card-ico, .why-card:hover .card-ico, .service-card:hover .card-ico{
  background:linear-gradient(135deg,var(--accent),var(--accent-glow)); color:#fff;
}
.card-link{ color:var(--accent); }
.card-link:hover{ color:var(--accent-glow); }

/* "What We Offer" — 3D Font Awesome icon cube */
.offer-cube-wrap{
  width:64px; height:64px; margin-bottom:24px;
  perspective:600px; perspective-origin:50% 40%;
}
.offer-cube{
  position:relative; width:64px; height:64px;
  transform-style:preserve-3d;
  transform:rotateX(-22deg) rotateY(-28deg);
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.service-card:hover .offer-cube{
  animation:offerCubeSpin 7s linear infinite;
}
.offer-cube__face{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:24px; color:var(--accent);
  background:var(--accent-soft);
  border:1.5px solid rgba(46, 46, 46,.30);
  border-radius:14px;
  backface-visibility:visible;
  box-shadow:inset 0 0 18px rgba(46, 46, 46,.06);
  transition:background .35s ease, color .35s ease, border-color .35s ease;
}
.service-card:hover .offer-cube__face{
  background:linear-gradient(135deg,var(--accent),var(--accent-glow));
  color:#fff; border-color:transparent;
}
.offer-cube__front  { transform:translateZ(32px); }
.offer-cube__back   { transform:translateZ(-32px) rotateY(180deg); }
.offer-cube__right  { transform:translateX(32px) rotateY(90deg); }
.offer-cube__left   { transform:translateX(-32px) rotateY(-90deg); }
.offer-cube__top    { transform:translateY(-32px) rotateX(90deg); }
.offer-cube__bottom { transform:translateY(32px) rotateX(-90deg); }
@keyframes offerCubeSpin{
  from{ transform:rotateX(-22deg) rotateY(0deg); }
  to  { transform:rotateX(-22deg) rotateY(360deg); }
}
@media (prefers-reduced-motion:reduce){
  .service-card:hover .offer-cube{ animation:none; transform:rotateX(-22deg) rotateY(-28deg); }
}

/* Project cards — charcoal wash on hover */
.project-card::after{ content:""; position:absolute; inset:0; opacity:0; transition:var(--transition);
  background:linear-gradient(180deg,rgba(17, 17, 17,0) 35%,rgba(17, 17, 17,.55) 100%); }
.project-card:hover::after{ opacity:1; }

/* CTA / Newsletter banners — deep charcoal gradient + soft glow */
.cta-band, .nl-band{
  background:linear-gradient(135deg,#161616 0%,#3a3a3a 60%,#2e2e2e 120%);
  position:relative; overflow:hidden;
}
.cta-band::before, .nl-band::before{
  content:""; position:absolute; width:520px; height:520px; right:-120px; top:-180px;
  background:radial-gradient(circle,rgba(154, 154, 154,.32),transparent 62%); pointer-events:none;
}
.cta-band > *, .nl-band > *{ position:relative; z-index:1; }

/* (Clients styling moved to the animated logo marquee block above) */
.client-marquee a.client-chip{ text-decoration:none; }

/* Quote / bullets / timeline accents already inherit charcoal via --accent */
.tl-item::before{ box-shadow:0 0 0 4px var(--accent-soft); }

/* Tabs active → charcoal gradient pill */
.tabs-nav button.active{ background:linear-gradient(135deg,var(--accent),var(--accent-glow)); border-color:transparent; }

/* Inputs focus ring */
.field-row input:focus, .field-row textarea:focus, .field-row select:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);
}

/* (Hero overlay + dots styling consolidated in the cinematic hero block above) */
