/*
Theme Name:  Prixateq Landing - New 3
Theme URI:   https://prixateq.com
Author:      Prixateq LLP
Version:     2.1.0
Text Domain: prixateq
*/

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

:root {
  --teal:      #0D2B2A;
  --teal-mid:  #163f3d;
  --teal-hi:   #1e5450;
  --gold:      #E8A020;
  --gold-dk:   #c8881a;
  --white:     #FFFFFF;
  --ink:       #111111;
  --muted:     #555555;
  --border:    rgba(0,0,0,0.09);
  --fd: 'Roboto Condensed', sans-serif;
  --fb: 'Roboto', sans-serif;
  --r: 4px;
  --max: 1340px;
  --t: 0.26s cubic-bezier(.4,0,.2,1);
}

body { font-family: var(--fb); background: #fff; color: #111; line-height: 1.6; -webkit-font-smoothing: antialiased; }
.container { max-width: var(--max); margin: 0 auto; padding: 0 2.5rem; }
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }

/* ── Animations ── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes pulse    { 0%,100%{opacity:.5;transform:scale(1)} 50%{opacity:1;transform:scale(1.08)} }

.reveal { opacity:0; transform:translateY(16px); transition:opacity .6s ease,transform .6s ease; }
.reveal.in { opacity:1; transform:none; }
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s}
.d4{transition-delay:.32s} .d5{transition-delay:.4s}

/* ═══════════════════════ NAV ═══════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background var(--t), box-shadow var(--t);
  background: rgba(13,43,42,0.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.nav.scrolled { background:var(--teal); box-shadow:0 2px 24px rgba(0,0,0,.35); backdrop-filter:none; }
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  height:68px; max-width:var(--max); margin:0 auto; padding:0 2.5rem;
}
.logo-wrap { display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-mark { width:36px; height:36px; flex-shrink:0; }
.logo-text {
  font-family:var(--fd); font-weight:700; font-size:16px;
  color:#ffffff; letter-spacing:.1em; text-transform:uppercase;
}
.nav__links { display:flex; align-items:center; gap:2.5rem; list-style:none; }
.nav__links a {
  font-size:13px; font-weight:500; color:rgba(255,255,255,.78);
  letter-spacing:.06em; text-transform:uppercase;
  transition:color var(--t); font-family:var(--fb);
}
.nav__links a:hover { color:#ffffff; }
.nav__cta {
  background:var(--gold); color:var(--teal) !important;
  font-size:12px; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  padding:10px 22px; border-radius:var(--r); transition:background var(--t),transform var(--t);
  white-space:nowrap; font-family:var(--fb);
}
.nav__cta:hover { background:var(--gold-dk); transform:translateY(-1px); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.hamburger span { width:22px; height:1.5px; background:#fff; border-radius:1px; display:block; }
.mobile-nav {
  display:none; position:fixed; inset:0; top:68px;
  background:var(--teal); flex-direction:column; align-items:center;
  justify-content:center; gap:2rem; z-index:99;
}
.mobile-nav.open { display:flex; }
.mobile-nav a { font-family:var(--fd); font-size:2rem; font-weight:700; color:#fff; }
.mobile-nav a:hover { color:var(--gold); }
.mobile-nav .nav__cta { font-size:14px; margin-top:.5rem; border-radius:var(--r); }

/* ═══════════════════════ HERO ═══════════════════════ */
.hero {
  position:relative; min-height:80vh; background:var(--teal);
  display:flex; align-items:center;
  padding:84px 0 56px; overflow:hidden;
}

/* Right-side circuit/tech image that fades left */
.hero__bg {
  position:absolute; right:0; top:0; bottom:0; width:62%; z-index:0; pointer-events:none;
}
.hero__bg img {
  width:100%; height:100%; object-fit:cover; object-position:center;
  opacity:.5;
  mix-blend-mode: luminosity;
  filter: hue-rotate(140deg) saturate(0.65) brightness(0.55);
}
.hero__bg-fade {
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(to right,
    #0D2B2A 0%,
    rgba(13,43,42,.97) 8%,
    rgba(13,43,42,.8)  25%,
    rgba(13,43,42,.35) 60%,
    rgba(13,43,42,.05) 90%,
    transparent 100%
  );
}
/* Top/bottom subtle fades */
.hero__bg-fade::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(to bottom,
    rgba(13,43,42,.3) 0%, transparent 20%,
    transparent 80%, rgba(13,43,42,.3) 100%
  );
}

/* Subtle gold glow */
.hero__glow {
  position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(232,160,32,.09) 0%,transparent 65%);
  top:-160px; left:20%; pointer-events:none; z-index:0;
}
/* Dot grid overlay */
.hero__grid { position:absolute; inset:0; pointer-events:none; z-index:0; }
.hero__grid::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:80px 80px;
}

.hero__inner { position:relative; z-index:2; width:100%; }
.hero__content { max-width:580px; }

.hero__eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  margin-bottom:1.1rem; font-size:11px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.6);
  font-family:var(--fb);
}
.hero__eyebrow-line { width:32px; height:2px; background:var(--gold); flex-shrink:0; }
.hero__eyebrow-text { color:var(--gold); }

h1.hero__h {
  font-family:var(--fd); font-size:clamp(2.6rem,4.5vw,4.4rem); font-weight:700; line-height:1.07;
  color:#ffffff; margin-bottom:1.1rem; letter-spacing:-.01em;
  animation:fadeUp .8s .1s ease both;
}
h1.hero__h em { font-style:italic; color:var(--gold); }

.hero__sub {
  font-size:17px; font-weight:400; color:rgba(255,255,255,.65); line-height:1.75;
  max-width:500px; margin-bottom:2rem; font-family:var(--fb);
  animation:fadeUp .8s .2s ease both;
}
.hero__actions { display:flex; gap:.75rem; flex-wrap:wrap; animation:fadeUp .8s .3s ease both; }

/* Credential badges */
.hero__creds { display:flex; flex-wrap:wrap; gap:.55rem; margin-top:1.4rem; animation:fadeUp .8s .42s ease both; }
.hero__cred {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 13px 5px 9px; border:1px solid rgba(255,255,255,.14);
  border-radius:20px; font-size:11px; font-weight:500;
  color:rgba(255,255,255,.62); background:rgba(255,255,255,.05);
  font-family:var(--fb);
}
.hero__cred svg { opacity:.7; }

/* ═══════════════════════ BUTTONS ═══════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--fb); font-size:13px; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase;
  padding:12px 24px; border-radius:var(--r); cursor:pointer; border:none; transition:all var(--t);
}
.btn--gold { background:var(--gold); color:var(--teal) !important; }
.btn--gold:hover { background:var(--gold-dk); transform:translateY(-2px); box-shadow:0 8px 24px rgba(232,160,32,.3); }
.btn--ghost { background:transparent; color:#fff !important; border:1.5px solid rgba(255,255,255,.28); }
.btn--ghost:hover { border-color:#fff; transform:translateY(-2px); }
.btn--dark { background:var(--teal); color:#fff !important; border:1.5px solid rgba(255,255,255,.14); }
.btn--dark:hover { background:var(--teal-mid); transform:translateY(-2px); }

/* ═══════════════════════ MARQUEE ═══════════════════════ */
.marquee { background:var(--teal-mid); padding:.85rem 0; overflow:hidden; border-top:1px solid rgba(255,255,255,.05); border-bottom:1px solid rgba(255,255,255,.05); }
.marquee__track { display:flex; animation:marquee 32s linear infinite; width:max-content; }
.marquee__track:hover { animation-play-state:paused; }
.marquee__item { display:flex; align-items:center; gap:.55rem; padding:0 2.5rem; font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.45); white-space:nowrap; font-family:var(--fb); }
.marquee__dot { width:3px; height:3px; border-radius:50%; background:var(--gold); flex-shrink:0; }

/* ═══════════════════════ STATS STRIP ═══════════════════════ */
.stats-strip { background:#fff; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stats-strip__inner { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-block { padding:1.75rem 1.5rem; text-align:center; border-right:1px solid var(--border); transition:background var(--t); }
.stat-block:last-child { border-right:none; }
.stat-block:hover { background:#f8fafa; }
.stat-block__n {
  font-family:var(--fd); font-size:2.7rem; font-weight:700; line-height:1;
  color:#111111 !important; margin-bottom:.3rem; font-variant-numeric:tabular-nums;
}
.stat-block:nth-child(2) .stat-block__n,
.stat-block:nth-child(4) .stat-block__n { color:var(--gold-dk) !important; }
.stat-block__l { font-size:13px; color:#666; font-family:var(--fb); }

/* ═══════════════════════ SECTION SHELL ═══════════════════════ */
.sec { padding:5rem 0; }
.sec--dark { background:var(--teal); }
.sec--darker { background:var(--teal-mid); }
.sec--white { background:#fff; }

.sec__eyebrow { display:flex; align-items:center; gap:10px; margin-bottom:.85rem; }
.sec__eyebrow-line { width:28px; height:2px; background:var(--gold); flex-shrink:0; }
.sec__eyebrow-text { font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-family:var(--fb); }

/* Section titles — forced dark on light, light on dark */
h2.sec__title {
  font-family:var(--fd) !important; font-size:clamp(2rem,3.2vw,3.2rem) !important;
  font-weight:700 !important; line-height:1.12 !important; margin-bottom:.75rem;
  color:#111111 !important; letter-spacing:-.01em;
}
h2.sec__title em { font-style:italic; }
.sec--dark  h2.sec__title,
.sec--darker h2.sec__title { color:#F0E6D0 !important; }
.sec__sub { font-size:16px; font-weight:400; line-height:1.75; color:#555; font-family:var(--fb); }
.sec--dark  .sec__sub,
.sec--darker .sec__sub { color:rgba(255,255,255,.55); }

/* ═══════════════════════ SERVICES ═══════════════════════ */
.services__head { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; margin-bottom:2.5rem; }
.services__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.svc {
  background:#fff; padding:1.6rem;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:background var(--t);
}
.svc::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform var(--t); }
.svc:hover { background:#fafafa; }
.svc:hover::after { transform:scaleX(1); }
.svc__icon-wrap { width:42px; height:42px; background:rgba(13,43,42,.07); border-radius:8px; display:flex; align-items:center; justify-content:center; margin-bottom:.8rem; flex-shrink:0; }
.svc__icon { width:21px; height:21px; color:var(--teal); }

/* CRITICAL: force visible titles — overrides any WP/Elementor global heading color */
.svc h3,
.svc .svc__title,
h3.svc__title,
.services__grid h3 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  margin-bottom: .45rem !important;
  color: #111111 !important;
  background: transparent !important;
  -webkit-text-fill-color: #111111 !important;
}

.svc__desc { font-size:15px; line-height:1.68; color:#555; flex:1; font-family:var(--fb); margin-bottom:.8rem; }
.svc__tags { display:flex; flex-wrap:wrap; gap:5px; margin-top:auto; }
.tag { font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:3px 8px; background:rgba(13,43,42,.07); color:var(--teal); border-radius:3px; font-family:var(--fb); }
.tag--g { background:rgba(232,160,32,.13); color:var(--gold-dk); }

/* ═══════════════════════ SCROLL CARDS ═══════════════════════ */
.hscroll-wrap { position:relative; margin-top:2rem; }
.hscroll { display:flex; gap:1.25rem; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding-bottom:.5rem; cursor:grab; }
.hscroll::-webkit-scrollbar { display:none; }
.hscroll.grabbing { cursor:grabbing; }
.hscroll-nav { display:flex; gap:.5rem; margin-top:1rem; }
.hscroll-btn { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:1.5px solid; cursor:pointer; transition:all var(--t); background:transparent; }
.hscroll-btn--light { border-color:rgba(0,0,0,.2); color:#111; }
.hscroll-btn--light:hover { background:var(--teal); color:#fff; border-color:var(--teal); }
.hscroll-btn--dark { border-color:rgba(255,255,255,.25); color:#fff; }
.hscroll-btn--dark:hover { background:rgba(255,255,255,.1); }

/* ═══════════════════════ CASE CARDS ═══════════════════════ */
.case-card { flex:0 0 380px; scroll-snap-align:start; background:#fff; border:1px solid var(--border); border-radius:6px; display:flex; flex-direction:column; overflow:hidden; transition:transform var(--t),box-shadow var(--t); }
.case-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.1); }
.case-card__img { width:100%; height:152px; object-fit:cover; flex-shrink:0; }
.case-card__top { padding:1.1rem 1.2rem .5rem; }
.case-card__sector { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-dk); background:rgba(232,160,32,.1); padding:3px 9px; border-radius:3px; display:inline-block; margin-bottom:.65rem; font-family:var(--fb); }

.case-card h3,
.case-card .case-card__title,
h3.case-card__title {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: #111111 !important;
  -webkit-text-fill-color: #111111 !important;
}

.case-card__desc { font-size:15px; line-height:1.65; color:#555; padding:.5rem 1.2rem 0; font-family:var(--fb); }
.case-card__outcomes { padding:.8rem 1.2rem 1rem; margin-top:auto; }
.case-card__outcomes-label { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#888; margin-bottom:.4rem; font-family:var(--fb); }
.outcome { display:flex; align-items:flex-start; gap:8px; font-size:14px; line-height:1.5; color:#111; margin-bottom:.3rem; font-family:var(--fb); }
.outcome::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--gold); flex-shrink:0; margin-top:5px; }
.case-card__footer { border-top:1px solid var(--border); padding:.6rem 1.2rem; display:flex; gap:5px; flex-wrap:wrap; }

/* ═══════════════════════ TESTIMONIALS ═══════════════════════ */
.tcard { flex:0 0 340px; scroll-snap-align:start; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:6px; padding:1.75rem; display:flex; flex-direction:column; transition:background var(--t),border-color var(--t); }
.tcard:hover { background:rgba(255,255,255,.08); border-color:rgba(232,160,32,.25); }
.tcard__stars { display:flex; gap:3px; margin-bottom:.85rem; }
.star { color:var(--gold); font-size:14px; }
.tcard__quote { font-family:var(--fb); font-size:15px; font-style:italic; line-height:1.65; color:rgba(255,255,255,.85); margin-bottom:1.25rem; flex:1; }
.tcard__author { display:flex; align-items:center; gap:10px; }
.tcard__av { width:36px; height:36px; border-radius:50%; background:var(--gold); color:var(--teal); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; flex-shrink:0; font-family:var(--fd); }
.tcard__name { font-size:14px; font-weight:700; color:#fff; font-family:var(--fb); }
.tcard__role { font-size:11px; color:rgba(255,255,255,.5); font-family:var(--fb); }

/* ═══════════════════════ HOW WE WORK ═══════════════════════ */
.process-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.07); border-radius:4px; overflow:hidden; margin-top:2.5rem; }
.pstep { padding:1.75rem 2rem; position:relative; }
.pstep:not(:last-child)::after {
  content:'→'; position:absolute; right:-14px; top:2.25rem;
  background:var(--gold); color:var(--teal); width:26px; height:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px; z-index:1;
}
.pstep__n { font-family:var(--fd); font-size:1.5rem; font-weight:700; color:rgba(232,160,32,.35); line-height:1; margin-bottom:.2rem; }
.pstep__t { font-family:var(--fd); font-size:1.3rem; font-weight:700; color:#F0E6D0 !important; margin-bottom:.35rem; }
.pstep__d { font-size:15px; color:rgba(255,255,255,.55); line-height:1.7; font-family:var(--fb); }

/* ═══════════════════════ ABOUT ═══════════════════════ */
.about__inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.about__body { font-size:16px; line-height:1.8; color:#555; margin-bottom:1rem; font-family:var(--fb); }
.about__pillars { display:grid; grid-template-columns:1fr 1fr; gap:.6rem; margin-top:1.5rem; }
.pillar { padding:1rem 1.1rem; border:1px solid var(--border); border-radius:var(--r); transition:border-color var(--t),background var(--t); }
.pillar:hover { border-color:rgba(232,160,32,.35); background:#fdfcf9; }
.pillar__head { display:flex; align-items:center; gap:8px; margin-bottom:.3rem; }
.pillar__ico { width:18px; height:18px; color:var(--teal); flex-shrink:0; }
.pillar__t { font-weight:700; font-size:14px; color:#111 !important; line-height:1; font-family:var(--fb); }
.pillar__d { font-size:13px; color:#666; line-height:1.5; padding-left:26px; font-family:var(--fb); }

/* About KPIs — styled like stats strip */
.about__kpis { display:grid; grid-template-columns:1fr; gap:1px; border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.kpi { background:#fff; padding:1.4rem 1.75rem; display:flex; align-items:center; gap:1.5rem; border-bottom:1px solid var(--border); transition:background var(--t); }
.kpi:last-child { border-bottom:none; }
.kpi:hover { background:#f8fafa; }
.kpi__n { font-family:var(--fd); font-size:2.4rem; font-weight:700; color:#111 !important; min-width:80px; font-variant-numeric:tabular-nums; }
.kpi:nth-child(2) .kpi__n { color:var(--gold-dk) !important; }
.kpi__l { font-size:15px; line-height:1.4; color:#555; font-family:var(--fb); }

/* ═══════════════════════ CTA BANNER ═══════════════════════ */
.cta-sec { background:var(--teal); padding:4.5rem 0; position:relative; overflow:hidden; }
.cta-sec__glow { position:absolute; inset:0; background:radial-gradient(ellipse at 65% 50%,rgba(232,160,32,.1) 0%,transparent 65%); pointer-events:none; }
.cta-sec__inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr auto; gap:4rem; align-items:center; }
.cta-sec__title { font-family:var(--fd); font-size:clamp(1.9rem,3.5vw,2.9rem); font-weight:700; line-height:1.1; color:#fff !important; }
.cta-sec__title em { font-style:italic; color:var(--gold); }
.cta-sec__sub { font-size:16px; color:rgba(255,255,255,.6); line-height:1.7; margin-top:.75rem; font-family:var(--fb); }
.cta-sec__btns { display:flex; flex-direction:column; gap:.6rem; align-items:flex-start; }

/* ═══════════════════════ CONTACT ═══════════════════════ */
.contact__inner { display:grid; grid-template-columns:1fr 1.1fr; gap:4rem; }
.contact__ttl { font-family:var(--fd); font-size:clamp(1.7rem,3vw,2.5rem); font-weight:700; line-height:1.15; margin-bottom:.75rem; color:#111 !important; }
.contact__body { font-size:16px; color:#555; line-height:1.75; margin-bottom:1.5rem; font-family:var(--fb); }
.contact__detail { display:flex; align-items:center; gap:10px; font-size:15px; color:#111 !important; margin-bottom:.65rem; font-family:var(--fb); }
.contact__detail a { color:#111 !important; }
.contact__ico { width:32px; height:32px; background:var(--teal); color:#fff; border-radius:var(--r); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact__form { background:#fff; border:1px solid var(--border); padding:2rem; border-radius:6px; box-shadow:0 4px 24px rgba(0,0,0,.06); }
.frow { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; margin-bottom:.75rem; }
.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:.75rem; }
.fg:last-of-type { margin-bottom:1.25rem; }
.flabel { font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:#666; font-family:var(--fb); }
.finput, .fselect, .ftextarea {
  font-family:var(--fb); font-size:13px; border:1.5px solid var(--border); border-radius:var(--r);
  padding:10px 12px; background:#fff; color:#111 !important; transition:border-color var(--t); width:100%; outline:none;
}
.finput:focus, .fselect:focus, .ftextarea:focus { border-color:var(--teal); }
.ftextarea { resize:vertical; min-height:90px; }
.fsubmit {
  width:100%; background:var(--teal); color:#fff !important;
  font-family:var(--fb); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:14px; border:none; border-radius:var(--r); cursor:pointer; transition:background var(--t),transform var(--t);
}
.fsubmit:hover { background:var(--teal-mid); transform:translateY(-1px); }

/* ═══════════════════════ FOOTER ═══════════════════════ */
.footer { background:var(--teal); border-top:5px solid var(--gold); padding:2.5rem 0 1.25rem; }
.footer__inner { display:grid; grid-template-columns:1.6fr 1fr 1.4fr; gap:3rem; margin-bottom:1.75rem; }
.footer__brand { display:flex; flex-direction:column; gap:.6rem; }
.footer__brand .logo-wrap { align-self:flex-start; }
.footer__brand-tagline { font-size:15px; color:#ffffff; line-height:1.65; font-family:var(--fb); }
.footer__social { display:flex; gap:6px; }
.fsoc { width:30px; height:30px; background:rgba(255,255,255,.08); border-radius:var(--r); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); transition:all var(--t); }
.fsoc:hover { background:var(--gold); color:var(--teal); }
.footer__col-ttl { font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:.85rem; font-family:var(--fb); }
.footer__nav { display:flex; flex-direction:column; gap:.5rem; }
.footer__nav a { font-size:14px; color:rgba(255,255,255,.7) !important; transition:color var(--t); font-family:var(--fb); }
.footer__nav a:hover { color:var(--gold) !important; }
.footer__contact-block { display:flex; flex-direction:column; gap:.6rem; }
.footer__contact-item { display:flex; align-items:flex-start; gap:8px; font-size:14px; color:rgba(255,255,255,.65) !important; line-height:1.55; font-family:var(--fb); }
.footer__contact-item svg { flex-shrink:0; margin-top:2px; opacity:.6; }
.footer__contact-item a { color:rgba(255,255,255,.65) !important; transition:color var(--t); }
.footer__contact-item a:hover { color:var(--gold) !important; }
.footer__bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:1rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.5rem; }
.footer__copy { font-size:13px; color:rgba(255,255,255,.38); font-family:var(--fb); }
.footer__legal { display:flex; gap:1.25rem; }
.footer__legal a { font-size:13px; color:rgba(255,255,255,.38) !important; transition:color var(--t); font-family:var(--fb); }
.footer__legal a:hover { color:rgba(255,255,255,.8) !important; }

/* ═══════════════════════ RESPONSIVE ═══════════════════════ */
@media(max-width:1200px){
  .container { padding:0 2rem; }
  .nav__inner { padding:0 2rem; }
}

@media(max-width:1024px){
  .hero__bg { width:55%; }
  .services__head { grid-template-columns:1fr; gap:1rem; }
  .services__grid { grid-template-columns:repeat(2,1fr); }
  .about__inner { grid-template-columns:1fr; gap:2.5rem; }
  .about__pillars { grid-template-columns:1fr 1fr; }
  .contact__inner { grid-template-columns:1fr; gap:2rem; }
  .footer__inner { grid-template-columns:1fr 1fr; gap:2rem; }
  .cta-sec__inner { grid-template-columns:1fr; gap:1.5rem; }
  .cta-sec__btns { flex-direction:row; flex-wrap:wrap; }
  .process-strip { grid-template-columns:1fr 1fr; }
  .pstep:nth-child(2)::after,
  .pstep:nth-child(3)::after { display:none; }
}

@media(max-width:768px){
  .nav__links, .nav__cta { display:none; }
  .hamburger { display:flex; }
  .sec { padding:3rem 0; }

  /* Hero */
  .hero { min-height:auto; padding:80px 0 44px; }
  .hero__bg { width:100%; opacity:.25; }
  .hero__bg-fade {
    background: linear-gradient(to bottom,
      #0D2B2A 0%, rgba(13,43,42,.95) 20%,
      rgba(13,43,42,.85) 70%, #0D2B2A 100%
    );
  }
  h1.hero__h { font-size:clamp(2rem,7.5vw,2.8rem); }
  .hero__sub { font-size:14px; max-width:100%; }
  .hero__creds { gap:.4rem; }
  .hero__cred { font-size:10px; padding:4px 10px; }

  /* Services */
  .services__grid { grid-template-columns:1fr; }
  .services__head { grid-template-columns:1fr; }

  /* Stats strip */
  .stats-strip__inner { grid-template-columns:repeat(2,1fr); }
  .stat-block:nth-child(2) { border-right:none; }
  .stat-block:nth-child(3),
  .stat-block:nth-child(4) { border-top:1px solid var(--border); }
  .stat-block__n { font-size:2.2rem !important; }

  /* Process — clean vertical stacked */
  .process-strip {
    grid-template-columns:1fr;
    gap:0;
    border-radius:6px;
    overflow:hidden;
  }
  .pstep { padding:1.25rem 1.5rem; border-bottom:1px solid rgba(255,255,255,.08); }
  .pstep:last-child { border-bottom:none; }
  .pstep::after { display:none !important; }
  .pstep__n { font-size:1.1rem; margin-bottom:.15rem; }

  /* Case / testimonial cards */
  .case-card { flex:0 0 290px; }
  .tcard { flex:0 0 270px; }

  /* About */
  .about__inner { grid-template-columns:1fr; }
  .about__pillars { grid-template-columns:1fr; }

  /* Forms */
  .frow { grid-template-columns:1fr; }

  /* Footer */
  .footer__inner { grid-template-columns:1fr; gap:1.5rem; }
  .footer__brand-tagline { max-width:100%; }
  .footer__nav { flex-direction:column; }

  /* CTA */
  .cta-sec__inner { gap:1.25rem; }
}

@media(max-width:480px){
  .container { padding:0 1.25rem; }
  .nav__inner { padding:0 1.25rem; }
  h1.hero__h { font-size:1.9rem; }
  .hero__actions { flex-direction:column; align-items:flex-start; }
  .btn { padding:11px 18px; font-size:12px; }
  h2.sec__title { font-size:1.7rem !important; }
  .case-card { flex:0 0 270px; }
  .tcard { flex:0 0 255px; }
  .stat-block { padding:1.25rem .75rem; }
  .stat-block__n { font-size:2rem !important; }
  .svc { padding:1.25rem; }
  .contact__form { padding:1.25rem; }
  .footer { padding:2rem 0 1rem; }
}

@media(max-width:360px){
  h1.hero__h { font-size:1.7rem; }
  .hero__creds { display:none; }
}
