/* =============================================================
   Hi-Tech Inspection Services LLC — Bold Industrial Theme
   Reference language: SGS / Bureau Veritas / TÜV — spacious,
   photo-led, big confident type, blue/white, restrained motion.
   ============================================================= */

:root{
  --blue:#0050B5;
  --blue-700:#013A86;
  --blue-50:#EAF1FB;
  --navy:#0A2240;
  --navy-800:#0E2C50;
  --red:#F41E1E;
  --red-700:#C8120F;
  --ink:#152334;
  --muted:#5A6878;
  --line:#E4EAF1;
  --bg:#FFFFFF;
  --bg-alt:#F4F7FB;
  --white:#fff;
  --container:1240px;
  --gut:clamp(20px,4vw,48px);
  --ff-head:'Roboto',system-ui,sans-serif;
  --ff-body:'Roboto',system-ui,sans-serif;
  --ff-display:'Teko','Roboto',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --shadow:0 30px 70px -40px rgba(10,34,64,.5);
  --shadow-sm:0 10px 30px -18px rgba(10,34,64,.4);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--bg);line-height:1.65;
  font-size:16.5px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-head);font-weight:700;line-height:1.08;margin:0;letter-spacing:-.02em;color:var(--navy)}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
::selection{background:var(--blue);color:#fff}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:3px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--gut);position:relative}
.section{padding:clamp(72px,10vw,130px) 0;position:relative}
.section--alt{background:var(--bg-alt)}
.section--navy{background:var(--navy);color:#fff}
.section--tight{padding:clamp(56px,7vw,90px) 0}

/* ---------- Section heads ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--ff-head);font-size:13px;
  font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:20px}
.eyebrow::before{content:"";width:32px;height:3px;background:var(--red)}
.eyebrow.center{justify-content:center}
.section--navy .eyebrow{color:#7DA9EE}
.section-head{max-width:740px;margin-bottom:clamp(40px,5vw,64px)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-title{font-size:clamp(30px,4.4vw,52px);line-height:1.04}
.section--navy .section-title{color:#fff}
.section-title em{color:var(--blue);font-style:normal}
.section--navy .section-title em{color:#7DA9EE}
.section-sub{margin-top:20px;color:var(--muted);font-size:clamp(16px,1.4vw,18.5px)}
.section--navy .section-sub{color:rgba(255,255,255,.75)}
.section-head.center .section-sub{margin-left:auto;margin-right:auto;max-width:62ch}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--ff-head);font-weight:600;font-size:15.5px;
  padding:16px 30px;border:2px solid transparent;cursor:pointer;transition:.25s var(--ease);white-space:nowrap;border-radius:2px}
.btn i,.btn svg{transition:transform .25s var(--ease)}
.btn:hover i,.btn:hover svg{transform:translateX(5px)}
.btn--red{background:var(--red);color:#fff;border-color:var(--red)}
.btn--red:hover{background:var(--red-700);border-color:var(--red-700)}
.btn--blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn--blue:hover{background:var(--blue-700);border-color:var(--blue-700)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn--light{background:#fff;color:var(--navy);border-color:#fff}
.btn--light:hover{background:var(--blue-50)}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn--outline-light:hover{background:#fff;color:var(--navy);border-color:#fff}
.linkarrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-head);font-weight:600;color:var(--blue);font-size:15px}
.linkarrow i{transition:transform .25s var(--ease)}
.linkarrow:hover i{transform:translateX(5px)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.3s var(--ease);padding:20px 0;background:transparent}
.site-header.is-stuck{background:#fff;box-shadow:0 8px 30px -20px rgba(10,34,64,.45);padding:12px 0}
.header-inner{display:flex;align-items:center;gap:30px}
.brand{background:#fff;border-radius:4px;padding:9px 16px;display:inline-flex;align-items:center;box-shadow:var(--shadow-sm);flex-shrink:0}
.brand img{height:44px;width:auto;transition:.3s}
.site-header.is-stuck .brand{box-shadow:none;padding:0;background:transparent}
.site-header.is-stuck .brand img{height:40px}
.main-nav{margin-left:auto}
.main-nav>ul{display:flex;align-items:center;gap:2px}
.main-nav a{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-head);font-weight:500;font-size:15px;
  color:#fff;padding:10px 14px;transition:.2s;position:relative;white-space:nowrap}
.site-header.is-stuck .main-nav a{color:var(--navy)}
.main-nav li{position:relative}
.main-nav .has-sub>a::after{content:"";width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;opacity:.55;margin-left:3px;transition:.2s}
.main-nav .has-sub:hover>a::after{opacity:.9;transform:translateY(1px)}
.main-nav>ul>li>a::before{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--red);
  transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
.main-nav>ul>li>a:hover::before{transform:scaleX(1)}
@media (min-width:1101px) and (max-width:1320px){.main-nav a{padding:10px 10px;font-size:14px}}
.submenu{position:absolute;top:calc(100% + 14px);left:0;min-width:250px;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(10px);transition:.22s var(--ease);z-index:50;border-radius:4px}
.submenu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.main-nav li:hover>.submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{color:var(--ink);font-size:14px;padding:11px 14px;display:block;border-radius:3px;border-left:2px solid transparent}
.submenu a:hover{background:var(--bg-alt);color:var(--blue);border-left-color:var(--red)}
.header-cta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.header-phone{display:none;text-align:right;line-height:1.25}
.header-phone small{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.site-header.is-stuck .header-phone small{color:var(--muted)}
.header-phone b{font-family:var(--ff-head);font-size:16px;color:#fff}
.site-header.is-stuck .header-phone b{color:var(--navy)}
.header-cta .btn{padding:12px 22px;font-size:14.5px}
.nav-toggle{display:none;background:rgba(255,255,255,.15);border:0;cursor:pointer;width:48px;height:48px;border-radius:4px;
  align-items:center;justify-content:center;color:#fff;font-size:20px}
.site-header.is-stuck .nav-toggle{color:var(--navy);background:var(--bg-alt)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;background:var(--navy);
  color:#fff;overflow:hidden;padding:clamp(92px,10vw,118px) 0 clamp(40px,5vw,54px)}
.hero__slides{position:absolute;inset:0;z-index:0;overflow:hidden;background:#0a2240}
.hero__slide{position:absolute;inset:0;z-index:0}
.hero__slide img{width:100%;height:100%;object-fit:cover}
.hero__slide.is-active{z-index:3}

/* is-prev: the outgoing image stays fully visible UNDER the incoming reveal,
   so a new slide always animates over a real photo — never the blue backing */
.hero__slide.is-prev{z-index:2;opacity:1!important;clip-path:none!important;transition:none!important}
.hero__slide.is-prev img{transform:scale(1)!important;filter:none!important;transition:none!important}
.hero__slide.is-prev .panel{transform:translateY(0)!important;transition:none!important}

/* fx: zoom-blur focus */
.hero__slide[data-fx="zoomblur"]{opacity:0;transition:opacity .9s ease}
.hero__slide[data-fx="zoomblur"] img{transform:scale(1.35);filter:blur(16px)}
.hero__slide[data-fx="zoomblur"].is-active{opacity:1}
.hero__slide[data-fx="zoomblur"].is-active img{transform:scale(1);filter:blur(0);transition:transform 1.2s cubic-bezier(.16,1,.3,1),filter 1s ease}

/* fx: vertical panels reveal */
.hero__slide[data-fx="panels"]{opacity:1}
.hero__slide[data-fx="panels"] .panel{position:absolute;top:0;height:100%;width:25%;overflow:hidden;transform:translateY(102%);transition:transform .9s cubic-bezier(.76,0,.24,1)}
.hero__slide[data-fx="panels"] .panel:nth-child(1){left:0}
.hero__slide[data-fx="panels"] .panel:nth-child(2){left:25%}
.hero__slide[data-fx="panels"] .panel:nth-child(3){left:50%}
.hero__slide[data-fx="panels"] .panel:nth-child(4){left:75%}
.hero__slide[data-fx="panels"] .panel img{position:absolute;top:0;left:0;height:100%;width:400%;max-width:none;object-fit:cover}
.hero__slide[data-fx="panels"] .panel:nth-child(2) img{left:-100%}
.hero__slide[data-fx="panels"] .panel:nth-child(3) img{left:-200%}
.hero__slide[data-fx="panels"] .panel:nth-child(4) img{left:-300%}
.hero__slide[data-fx="panels"].is-active .panel{transform:translateY(0)}
.hero__slide[data-fx="panels"].is-active .panel:nth-child(2){transition-delay:.1s}
.hero__slide[data-fx="panels"].is-active .panel:nth-child(3){transition-delay:.2s}
.hero__slide[data-fx="panels"].is-active .panel:nth-child(4){transition-delay:.3s}

/* fx: circle reveal */
.hero__slide[data-fx="circle"]{opacity:1;clip-path:circle(0% at 50% 50%);transition:clip-path 1.15s cubic-bezier(.76,0,.24,1)}
.hero__slide[data-fx="circle"] img{transform:scale(1.12)}
.hero__slide[data-fx="circle"].is-active{clip-path:circle(75% at 50% 50%)}
.hero__slide[data-fx="circle"].is-active img{transform:scale(1);transition:transform 6s ease-out}

/* fx: curtain wipe (reveals top -> bottom) */
.hero__slide[data-fx="wipe"]{opacity:1;clip-path:inset(0 0 100% 0);transition:clip-path 1.05s cubic-bezier(.76,0,.24,1)}
.hero__slide[data-fx="wipe"] img{transform:scale(1.18)}
.hero__slide[data-fx="wipe"].is-active{clip-path:inset(0 0 0 0)}
.hero__slide[data-fx="wipe"].is-active img{transform:scale(1);transition:transform 5s ease-out}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(96deg,rgba(10,34,64,.93) 0%,rgba(10, 34, 64, 0.603) 42%,rgba(10,34,64,.34) 72%,rgba(10,34,64,.12) 100%)}
.hero__scrim::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,34,64,.85),transparent 46%)}
.hero .container{z-index:3}
.hero__inner{max-width:840px}
.hero__eyebrow,.hero__lead,.hero__actions{opacity:0;transform:translateY(28px)}
.hero.is-ready .hero__eyebrow{animation:heroIn .8s var(--ease) .12s forwards}
.hero.is-ready .hero__lead{animation:heroIn .9s var(--ease) .42s forwards}
.hero.is-ready .hero__actions{animation:heroIn .9s var(--ease) .56s forwards}
@keyframes heroIn{to{opacity:1;transform:none}}
.hero__eyebrow{display:inline-flex;align-items:center;gap:13px;font-family:var(--ff-head);font-size:13.5px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:26px;padding:9px 16px;
  border:1px solid rgba(255,255,255,.25);border-radius:2px;background:rgba(255,255,255,.06)}
.hero__eyebrow .blip{width:8px;height:8px;border-radius:50%;background:var(--red)}
.hero h1{color:#fff;font-size:clamp(38px,6.2vw,78px);line-height:1.02;letter-spacing:-.025em;text-transform:uppercase}
.hero h1 em{color:#f41e1e;font-style:normal}
/* hero title — per-word slide-up reveal (on load + each slide) */
.hero h1 .hw{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.06em;margin-bottom:-.06em}
.hero h1 .hw>span{display:inline-block;transform:translateY(110%);transition:transform .6s var(--ease)}
.hero h1 .hw>span.em{color:#f41e1e}
.hero h1.is-anim .hw>span{transform:translateY(0)}
.hero__lead{margin-top:26px;font-size:clamp(17px,1.6vw,20px);color:rgba(255,255,255,.85);max-width:60ch;line-height:1.6;
  transition:opacity .5s var(--ease)}
.hero__lead.is-swapping{opacity:0}
.hero__actions{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__dots{position:relative;margin-top:clamp(22px,3vw,34px);z-index:3}
.hero__dots .container{display:flex;gap:10px;align-items:center}
.hero__dots .idx{font-family:var(--ff-head);font-size:13px;letter-spacing:.15em;color:rgba(255,255,255,.6);margin-right:14px}
.hero__dots .idx b{color:#fff}
.hero__dots button{flex:0 0 auto;width:46px;height:3px;background:rgba(255,255,255,.28);border:0;cursor:pointer;transition:.3s;padding:0;position:relative;overflow:hidden}
.hero__dots button.is-active{width:80px;background:rgba(255,255,255,.3)}
.hero__dots button.is-active::after{content:"";position:absolute;inset:0;background:var(--red);transform-origin:left;animation:dotfill 6.5s linear forwards}
@keyframes dotfill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hero__badge{position:absolute;right:var(--gut);bottom:46px;z-index:3;display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);padding:16px 22px;border-radius:3px}
.hero__badge .ic{width:44px;height:44px;border-radius:3px;background:var(--red);display:grid;place-items:center;color:#fff;font-size:19px}
.hero__badge small{display:block;font-size:11.5px;letter-spacing:.06em;color:rgba(255,255,255,.7);text-transform:uppercase}
.hero__badge b{font-family:var(--ff-head);font-size:14.5px}

/* ---------- Stats band ---------- */
.statband{background:var(--navy);color:#fff}
.statband__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.statband__item{padding:clamp(22px,2.4vw,32px) clamp(20px,2.4vw,40px);border-right:1px solid rgba(255,255,255,.12);position:relative}
.statband__item:last-child{border-right:0}
.statband__num{font-family:var(--ff-head);font-weight:700;font-size:clamp(28px,3vw,42px);line-height:1;color:#fff}
.statband__num span{color:var(--red)}
.statband__label{margin-top:8px;color:rgba(255,255,255,.7);font-size:14px;max-width:22ch}

/* ---------- Split / editorial ---------- */
.split{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,5.5vw,80px);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative}
.split__media>img{width:100%;height:100%;max-height:560px;object-fit:cover;border-radius:4px}
.split__media .accent{position:absolute;left:-22px;bottom:-22px;width:160px;height:160px;border-left:5px solid var(--red);border-bottom:5px solid var(--red);z-index:-1}
.split__media .chip{position:absolute;right:-14px;top:34px;background:var(--blue);color:#fff;padding:18px 22px;border-radius:3px;box-shadow:var(--shadow)}
.split__media .chip b{font-family:var(--ff-head);font-size:30px;display:block;line-height:1}
.split__media .chip span{font-size:12.5px;opacity:.9;letter-spacing:.04em}
.vmlist{display:grid;gap:18px;margin-top:30px}
.vmlist .vm{display:flex;gap:18px;padding:22px 24px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:3px}
.vmlist .vm.vm--red{border-left-color:var(--red)}
.vmlist .vm .ic{flex:0 0 auto;width:46px;height:46px;border-radius:3px;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-size:19px}
.vmlist .vm.vm--red .ic{background:#FDE9E9;color:var(--red)}
.vmlist .vm h3{font-size:18px;margin-bottom:6px}
.vmlist .vm p{color:var(--muted);font-size:15px}
.ticks{display:grid;gap:14px;margin:24px 0 30px}
.ticks li{position:relative;padding-left:36px;color:var(--ink);font-size:16px}
.ticks li::before{content:"\2713";font-family:var(--ff-body);font-weight:700;color:#fff;background:var(--blue);
  position:absolute;left:0;top:2px;width:24px;height:24px;border-radius:2px;display:grid;place-items:center;font-size:13px;line-height:1}

/* ---------- Who We Are (Demo-3 about layout, clean bg) ---------- */
.ab3{position:relative;background:#fff;overflow:hidden;padding:clamp(64px,8vw,112px) 0 0}
.ab3__title{display:grid;grid-template-columns:1.2fr 1fr auto;gap:clamp(28px,4vw,60px);align-items:start;
  margin-bottom:clamp(44px,5vw,72px)}
.ab3__sub{display:flex;align-items:center;gap:14px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.ab3__sub .n{font-family:var(--ff-display);font-size:24px;font-weight:600;color:var(--blue);letter-spacing:.02em}
.ab3 .section-title{text-transform:uppercase;max-width:16ch}
.ab3__mid p{color:#445268;font-size:16.5px;line-height:1.75;margin-bottom:24px}
.ab3__seal{flex:0 0 auto;width:148px;height:148px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:3px;box-shadow:var(--shadow);justify-self:end}
.ab3__seal-ic{font-size:22px;color:#7DA9EE}
.ab3__seal b{font-family:var(--ff-display);font-size:21px;font-weight:600;line-height:.92;color:#fff}
.ab3__seal small{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.72)}
/* curved-tab image panel (exact Demo-3 video-3 clip-path) with our real image */
.ab3__media{position:relative;margin-top:clamp(-16px,-2vw,-36px)}
.ab3__panel{position:relative;width:100%;height:clamp(360px,44vw,580px);overflow:hidden;
  clip-path:polygon(72.16% 17.5%,72.16% 17.5%,72.972% 17.311%,73.747% 16.763%,74.477% 15.882%,75.153% 14.696%,75.767% 13.23%,76.31% 11.512%,76.774% 9.569%,77.15% 7.428%,77.431% 5.115%,77.606% 2.657%,77.606% 2.657%,77.636% 2.229%,77.683% 1.822%,77.746% 1.441%,77.822% 1.093%,77.913% 0.782%,78.015% 0.516%,78.127% 0.299%,78.249% 0.137%,78.38% 0.035%,78.517% 0%,99.153% 0%,99.153% 0%,99.29% 0.035%,99.42% 0.136%,99.542% 0.298%,99.653% 0.515%,99.752% 0.781%,99.837% 1.092%,99.905% 1.441%,99.957% 1.824%,99.989% 2.234%,100% 2.667%,100% 97.333%,100% 97.333%,99.989% 97.766%,99.957% 98.176%,99.905% 98.559%,99.837% 98.908%,99.752% 99.219%,99.653% 99.486%,99.542% 99.702%,99.42% 99.864%,99.29% 99.965%,99.153% 100%,0.847% 100%,0.847% 100%,0.71% 99.965%,0.58% 99.864%,0.458% 99.702%,0.347% 99.486%,0.248% 99.219%,0.164% 98.908%,0.095% 98.559%,0.043% 98.176%,0.011% 97.766%,0% 97.333%,0% 2.667%,0% 2.667%,0.011% 2.234%,0.043% 1.824%,0.095% 1.441%,0.164% 1.092%,0.248% 0.781%,0.347% 0.515%,0.458% 0.298%,0.58% 0.136%,0.71% 0.035%,0.847% 0%,65.805% 0%,65.805% 0%,65.942% 0.035%,66.072% 0.137%,66.194% 0.299%,66.307% 0.516%,66.409% 0.782%,66.499% 1.093%,66.576% 1.441%,66.638% 1.822%,66.685% 2.229%,66.715% 2.657%,66.715% 2.657%,66.891% 5.115%,67.171% 7.428%,67.548% 9.569%,68.012% 11.512%,68.555% 13.23%,69.168% 14.696%,69.844% 15.882%,70.574% 16.763%,71.349% 17.311%,72.16% 17.5%)}
.ab3__panel img{width:100%;height:100%;object-fit:cover;object-position:center 38%;display:block}
@media (max-width:1000px){
  .ab3__title{grid-template-columns:1fr;gap:24px}
  .ab3__seal{justify-self:start}
  .ab3__panel{clip-path:none;height:clamp(300px,60vw,420px)}
}

/* ---------- Services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc{position:relative;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:.3s var(--ease)}
.svc:hover{box-shadow:var(--shadow);transform:translateY(-5px);border-color:transparent}
.svc__media{aspect-ratio:16/10;overflow:hidden;position:relative}
.svc__media img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.svc:hover .svc__media img{transform:scale(1.07)}
.svc__num{position:absolute;left:0;top:0;background:var(--blue);color:#fff;font-family:var(--ff-head);font-weight:700;
  font-size:14px;padding:8px 13px;letter-spacing:.05em}
.svc__body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.svc__body h3{font-size:20px;margin-bottom:10px}
.svc__body p{color:var(--muted);font-size:14.5px;flex:1;line-height:1.6}
.svc__body .linkarrow{margin-top:18px}

/* ---------- Sectors (editorial overlay tiles) ---------- */
.sectors{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:300px;gap:18px}
.sector{position:relative;overflow:hidden;border-radius:4px;display:flex;align-items:flex-end;color:#fff;grid-column:span 2}
.sector--tall{grid-row:span 2}
.sector--wide{grid-column:span 4}
.sector--half{grid-column:span 3}
.sector img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.sector::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,34,64,.94),rgba(10,34,64,.15) 72%)}
.sector:hover img{transform:scale(1.06)}
.sector__body{position:relative;z-index:2;padding:30px}
.sector__k{font-family:var(--ff-head);font-size:13px;color:#7DA9EE;letter-spacing:.1em;display:block;margin-bottom:8px}
.sector__body h3{color:#fff;font-size:24px;margin-bottom:8px}
.sector__body p{color:rgba(255,255,255,.82);font-size:14.5px;max-width:46ch}

/* ---------- Certifications band ---------- */
.certs{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);background:#fff;border-radius:4px;overflow:hidden}
.cert{padding:34px 26px;display:flex;flex-direction:column;align-items:center;text-align:center;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:.25s}
.cert:hover{background:var(--bg-alt)}
.cert img{height:96px;width:auto;object-fit:contain;margin-bottom:16px}
.cert b{font-family:var(--ff-head);font-size:15px;color:var(--navy)}
.cert span{font-size:12.5px;color:var(--muted);margin-top:3px}
.certnote{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:28px}
.certnote span{border:1px solid var(--line);background:#fff;border-radius:2px;padding:9px 18px;font-size:14px;font-family:var(--ff-head);font-weight:500;color:var(--ink)}
.certnote span b{color:var(--blue)}

/* ---------- CTA band ---------- */
.ctaband{position:relative;overflow:hidden;background:var(--blue);color:#fff}
.ctaband__bg{position:absolute;inset:0;opacity:.16;object-fit:cover;width:100%;height:100%}
.ctaband__in{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;
  padding:clamp(48px,6vw,80px) 0}
.ctaband h2{color:#fff;font-size:clamp(28px,3.6vw,44px);max-width:20ch}
.ctaband__actions{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:rgba(255,255,255,.72)}
.site-footer::before{content:"";display:block;height:4px;background:linear-gradient(90deg,var(--blue),var(--red))}
.footer-top{padding:80px 0 56px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:44px}
.footer-brand{background:#fff;border-radius:4px;padding:12px 16px;display:inline-flex;margin-bottom:24px}
.footer-brand img{height:48px}
.site-footer h4{color:#fff;font-size:15px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:22px}
.site-footer ul li{margin-bottom:12px}
.site-footer ul a{font-size:14.5px;transition:.2s}
.site-footer ul a:hover{color:#fff;padding-left:5px}
.footer-contact li{display:flex;gap:13px;margin-bottom:16px;font-size:14.5px;line-height:1.5}
.footer-contact i{color:#7DA9EE;margin-top:4px;flex:0 0 auto}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13.5px}
.footer-bottom a:hover{color:#fff}

/* ---------- Page banner (inner pages) ---------- */
.page-banner{position:relative;background:var(--navy);color:#fff;padding:170px 0 80px;overflow:hidden}
.page-banner__bg{position:absolute;inset:0}
.page-banner__bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.page-banner__bg::after{display:none}
.page-banner .container{position:relative;z-index:2}
.page-banner h1{color:#fff;font-size:clamp(34px,5vw,60px);text-transform:uppercase}
.crumb{display:flex;gap:11px;align-items:center;font-size:14px;color:rgba(255,255,255,.7);margin-top:16px;font-family:var(--ff-head)}
.crumb a:hover{color:#fff}.crumb .sep{color:#7DA9EE}

/* ---------- Prose ---------- */
.prose h2{font-size:clamp(24px,3vw,34px);margin:38px 0 16px}
.prose h3{font-size:21px;margin:28px 0 12px}
.prose p{color:var(--muted);margin-bottom:16px}
.prose img{width:100%;height:auto;border-radius:12px;margin:10px 0 24px;display:block}

/* ---------- Forgex-style feature section (big title / copy / image) ---------- */
.fxsec{position:relative;padding:clamp(64px,7.5vw,118px) 0}
.fxsec__grid{display:grid;grid-template-columns:1.12fr .82fr .92fr;gap:clamp(28px,4vw,58px);align-items:center}
.fxsec__title{font-family:var(--ff-display);text-transform:uppercase;font-weight:600;font-size:clamp(42px,6.2vw,88px);line-height:.84;letter-spacing:-1px;color:var(--navy);margin:0}
.fxsec__title em{color:var(--blue);font-style:normal}
.fxsec__para{font-size:18px;line-height:1.72;color:#445268;margin:0 0 28px}
.fxsec__media{position:relative}
.fxsec__media img{width:100%;height:auto;display:block;border-radius:16px;box-shadow:var(--shadow)}
.fxsec__media .accent{position:absolute;left:-20px;bottom:-20px;width:150px;height:150px;border-left:5px solid var(--red);border-bottom:5px solid var(--red);z-index:-1}
@media(max-width:980px){.fxsec__grid{grid-template-columns:1fr 1fr;gap:38px 44px}.fxsec__media{grid-column:1 / -1;max-width:560px}}
@media(max-width:600px){.fxsec__grid{grid-template-columns:1fr}}

/* ---------- Home: numbered eyebrow (Demo-3 rhythm) ---------- */
.eyebrow--num{display:inline-flex;align-items:center;gap:12px}
.eyebrow--num .num{font-family:var(--ff-display);font-size:22px;font-weight:700;color:var(--red);line-height:1}
.eyebrow--num.center{justify-content:center}

/* ---------- Home: feature image shown in full (no crop) ---------- */
.split__media--free{display:block;z-index:1}
.split__media--free>img{width:100%;height:auto;max-height:none;object-fit:contain;border-radius:12px;box-shadow:var(--shadow);background:#eef2f7}

/* ---------- Home: capabilities gallery (full portrait images, staggered) ---------- */
.capgal{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.capgal figure{margin:0;overflow:hidden;border-radius:14px;box-shadow:var(--shadow-sm);transition:.5s var(--ease)}
.capgal figure:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.capgal img{display:block;width:100%;height:auto;border-radius:14px}
@media(max-width:760px){.capgal{grid-template-columns:1fr;max-width:430px;margin-left:auto;margin-right:auto}}

/* ---------- Home: custom-solutions full banner with overlaid caption (no crop) ---------- */
.custband{position:relative;display:block;overflow:hidden}
.custband>img{display:block;width:100%;height:auto}
.custband__in{position:absolute;left:0;right:0;bottom:0;z-index:2;color:#fff;padding:clamp(26px,5vw,64px) 0;background:linear-gradient(to top,rgba(8,28,54,.94),rgba(8,28,54,.5) 58%,rgba(8,28,54,0))}
.custband__in .section-title{color:#fff;margin:0}
.custband__in .eyebrow{color:#fff}
@media(max-width:620px){.custband__in{position:static;background:var(--navy);padding:24px 0}}
.prose--center{max-width:880px;margin:0 auto;text-align:center}
.prose--center p{font-size:17px;line-height:1.8}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:8px;font-family:var(--ff-head)}
.field input,.field select,.field textarea{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:3px;
  font-family:var(--ff-body);font-size:15px;color:var(--ink);background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,80,181,.1)}

/* ---------- Display font (Teko) for big titles, like Demo 3 ---------- */
.hero h1,.section-title,.page-banner h1,.statband__num,.ctaband h2{font-family:var(--ff-display);font-weight:600;letter-spacing:.005em}
.hero h1{font-weight:600;letter-spacing:.01em;line-height:.96}
.section-title{font-weight:600;line-height:1}
.statband__num{font-weight:600}

/* ---------- Split-text title reveal (Demo-3 style: per-char brighten) ---------- */
.split-reveal .wd{display:inline-block;white-space:nowrap}
.split-reveal .ch{display:inline-block;opacity:.2;transform:translateX(-6px);
  transition:opacity .5s var(--ease),transform .5s var(--ease)}
.split-reveal .ch.em{color:var(--blue)}
.section--navy .split-reveal .ch.em{color:#7DA9EE}
.split-reveal.is-split-in .ch{opacity:1;transform:none}

/* ---------- Reveal (subtle, professional) ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}

/* ---------- Mobile menu ---------- */
.mobile-menu{position:fixed;inset:0;z-index:1100;background:var(--navy);color:#fff;padding:90px 28px 40px;
  transform:translateX(100%);transition:.35s var(--ease);overflow-y:auto;visibility:hidden;
  display:block !important}                 /* override Forgex main.css .mobile-menu{display:none} on the homepage */
.mobile-menu.is-open{transform:none;visibility:visible}
.mobile-menu__close{position:absolute;top:24px;right:24px;background:rgba(255,255,255,.14);border:0;color:#fff;width:48px;height:48px;border-radius:4px;font-size:20px;cursor:pointer}
.mobile-menu>ul>li{border-bottom:1px solid rgba(255,255,255,.12)}
.mobile-menu>ul>li>a{display:block;padding:16px 4px;font-family:var(--ff-head);font-size:19px;font-weight:600}
.mobile-menu .submenu-m a{display:block;padding:7px 16px;color:rgba(255,255,255,.7);font-size:15px}
.mobile-menu .btn{margin-top:26px;width:100%;justify-content:center}
.scroll-lock{overflow:hidden}

/* ---------- Responsive ---------- */
@media (min-width:1101px){.header-phone{display:block}}
@media (max-width:1100px){
  .main-nav,.header-phone{display:none}
  .header-cta{margin-left:auto}
  .nav-toggle{display:inline-flex}
  .split{grid-template-columns:1fr;gap:44px}.split--rev .split__media{order:0}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .sectors{grid-template-columns:repeat(2,1fr);grid-auto-rows:260px}
  .sector,.sector--wide,.sector--half{grid-column:span 1}.sector--tall{grid-row:span 1}
  .certs{grid-template-columns:repeat(2,1fr)}
  .statband__grid{grid-template-columns:repeat(2,1fr)}
  .statband__item:nth-child(2){border-right:0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero__badge{display:none}
}
@media (max-width:640px){
  .header-cta .btn--red{display:none}              /* CTA lives in the mobile menu; keep header = logo + menu */
  .header-inner{gap:14px}
  .svc-grid,.sectors,.certs,.statband__grid,.footer-grid{grid-template-columns:1fr}
  .statband__item,.cert{border-right:0}
  .ctaband__in{flex-direction:column;align-items:flex-start}
  .split__media .chip{position:static;display:inline-block;margin-top:16px}
  .split__media .accent{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.01ms!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .hero__slide img{transform:none!important}
  .hero__eyebrow,.hero h1,.hero__lead,.hero__actions{opacity:1!important;transform:none!important;animation:none!important}
}

/* ---------- Policy cards (policies.html) ---------- */
.policy-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.policy-card{background:#fff;border:1px solid var(--line);border-top:4px solid var(--blue);border-radius:4px;padding:36px 30px 30px;display:flex;flex-direction:column;transition:.25s var(--ease)}
.policy-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.policy-card.policy-card--red{border-top-color:var(--red)}
.policy-card.policy-card--navy{border-top-color:var(--navy)}
.policy-card__ic{width:52px;height:52px;border-radius:4px;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-size:22px;margin-bottom:22px;flex-shrink:0}
.policy-card--red .policy-card__ic{background:#FDE9E9;color:var(--red)}
.policy-card--navy .policy-card__ic{background:rgba(10,34,64,.08);color:var(--navy)}
.policy-card h3{font-size:20px;margin-bottom:12px;color:var(--navy)}
.policy-card p{color:var(--muted);font-size:15px;line-height:1.65;flex:1}
.policy-card .linkarrow{margin-top:22px}
@media (max-width:900px){.policy-cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.policy-cards{grid-template-columns:1fr}}

/* ---------- Added for contact / careers / hse pages (reuses existing tokens) ---------- */
/* 4-up variant of the policy-card grid (careers "why work with us") */
.policy-cards--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1080px){.policy-cards--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.policy-cards--4{grid-template-columns:1fr}}
.policy-cards--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:768px){.policy-cards--2{grid-template-columns:1fr}}

/* Contact info card (contact.html) */
.infocard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:clamp(28px,3vw,40px);box-shadow:var(--shadow)}
.infocard h3{font-size:22px;color:var(--navy);margin-bottom:6px}
.infocard__sub{color:var(--muted);font-size:15px;margin-bottom:24px}
.infolist{display:grid;gap:20px}
.infolist__row{display:flex;gap:16px;align-items:flex-start}
.infolist__ic{flex:0 0 auto;width:44px;height:44px;border-radius:4px;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-size:18px}
.infolist__row:nth-child(2) .infolist__ic{background:#FDE9E9;color:var(--red)}
.infolist__k{display:block;font-family:var(--ff-head);font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--navy);margin-bottom:4px}
.infolist__v{color:var(--muted);font-size:15px;line-height:1.6}
.infolist__v a{color:var(--muted)}
.infolist__v a:hover{color:var(--blue)}
.map-embed{border-radius:4px;overflow:hidden;border:1px solid var(--line);line-height:0}
.map-embed iframe{width:100%;height:420px;border:0;display:block}

/* Honest empty-state block (news.html) */
.emptystate{text-align:center;max-width:640px;margin:0 auto;padding:clamp(48px,6vw,72px) clamp(24px,4vw,48px);background:#fff;border:1px dashed var(--line);border-radius:6px}
.emptystate__ic{width:72px;height:72px;border-radius:50%;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-size:30px;margin:0 auto 22px}
.emptystate h3{font-size:24px;color:var(--navy);margin-bottom:12px}
.emptystate p{color:var(--muted);font-size:16px;line-height:1.7}

/* Definition chips (hse LTI/MVI) */
.defrow{display:flex;gap:18px;flex-wrap:wrap;margin-top:26px}
.defchip{flex:1 1 240px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:3px;padding:18px 22px}
.defchip:last-child{border-left-color:var(--red)}
.defchip b{font-family:var(--ff-head);color:var(--navy);font-size:18px;display:block;margin-bottom:4px}
.defchip span{color:var(--muted);font-size:14.5px}

/* ---------- About — office contacts block ---------- */
.aboutc{display:grid;grid-template-columns:1fr auto;gap:clamp(30px,5vw,64px);align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:clamp(28px,4vw,48px);box-shadow:var(--shadow-sm)}
.aboutc__list li{display:flex;gap:16px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--line);font-size:16px;color:var(--ink)}
.aboutc__list li:last-child{border-bottom:0}
.aboutc__list i{color:var(--blue);margin-top:4px;width:20px;text-align:center;flex:0 0 auto}
.aboutc__qr{text-align:center;flex:0 0 auto}
.aboutc__qr img{width:160px;height:160px;border:1px solid var(--line);border-radius:8px}
.aboutc__qr span{display:block;margin-top:10px;font-size:12.5px;color:var(--muted)}
@media(max-width:720px){.aboutc{grid-template-columns:1fr}.aboutc__qr{justify-self:start}}

/* ---------- Vision / Mission cards (restored) ---------- */
.about2__vm{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vm2{position:relative;background:#fff;border-radius:12px;padding:clamp(26px,3vw,40px);box-shadow:var(--shadow-sm);overflow:hidden;transition:.3s var(--ease)}
.vm2::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--blue)}
.vm2--red::before{background:var(--red)}
.vm2:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.vm2__no{position:absolute;top:4px;right:22px;font-family:var(--ff-display);font-size:104px;font-weight:700;line-height:1;color:rgba(0,80,181,.07);pointer-events:none}
.vm2--red .vm2__no{color:rgba(244,30,30,.07)}
.vm2__head{display:flex;align-items:center;gap:16px;margin-bottom:14px;position:relative}
.vm2 .ic{flex:0 0 auto;width:54px;height:54px;border-radius:50%;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-size:22px}
.vm2--red .ic{background:#FDE9E9;color:var(--red)}
.vm2 h3{font-family:var(--ff-display);font-size:26px;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.01em}
.vm2 p{color:#445268;font-size:16px;line-height:1.7}
@media (max-width:760px){.about2__vm{grid-template-columns:1fr}}

/* ---------- About — office location map ---------- */
.aboutc-map{margin-top:26px;border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);line-height:0}
.aboutc-map iframe{display:block;width:100%}

/* ---------- Policies — actual PDF documents ---------- */
.policy-docs{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px)}
.policy-doc{margin:0;text-align:center}
.policy-doc h3{font-family:var(--ff-display);font-size:26px;font-weight:600;color:var(--navy);text-transform:uppercase;margin-bottom:18px}
.policy-doc__frame{position:relative;display:block;background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px;
  box-shadow:var(--shadow-sm);transition:.3s var(--ease);overflow:hidden}
.policy-doc__frame img{width:100%;height:auto;display:block;border:1px solid var(--line)}
.policy-doc__frame:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--blue)}
.policy-doc__view{position:absolute;left:50%;bottom:24px;transform:translateX(-50%) translateY(8px);opacity:0;transition:.3s var(--ease);
  display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;font-family:var(--ff-head);font-weight:600;font-size:14px;padding:11px 22px;border-radius:2px}
.policy-doc__frame:hover .policy-doc__view{opacity:1;transform:translateX(-50%) translateY(0)}
@media (max-width:760px){.policy-docs{grid-template-columns:1fr;gap:36px}}

/* ---------- Certifications — grouped accreditation register ---------- */
.cert-reg{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.cert-reg__col{display:flex;flex-direction:column;gap:24px}
.cert-grp{background:#fff;border:1px solid var(--line);border-top:3px solid var(--blue);border-radius:10px;
  padding:24px 28px;box-shadow:var(--shadow-sm)}
.cert-grp h3{display:flex;align-items:center;gap:12px;font-family:var(--ff-display);font-size:18px;font-weight:600;
  color:var(--navy);text-transform:uppercase;letter-spacing:.01em;margin-bottom:6px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.cert-grp h3 i{color:var(--blue);font-size:16px}
.cert-grp ul li{padding:11px 0;border-bottom:1px dashed var(--line);color:var(--ink);font-size:15px;line-height:1.5}
.cert-grp ul li:last-child{border-bottom:0}
.cert-grp ul li b{display:block;margin-top:3px;font-family:var(--ff-mono);font-size:12.5px;font-weight:600;color:var(--blue);letter-spacing:.02em}
@media(max-width:760px){.cert-reg{grid-template-columns:1fr;gap:20px}.cert-reg__col{gap:20px}}

/* ---------- Certificate document gallery (opens real PDFs) ---------- */
.certgal{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.certdoc{position:relative;display:block;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:.3s var(--ease)}
.certdoc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--blue)}
.certdoc__img{aspect-ratio:3/4;background:#f4f7fb;display:grid;place-items:center;padding:16px}
.certdoc__img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:var(--shadow-sm)}
.certdoc__cap{padding:14px 16px;border-top:1px solid var(--line);text-align:center}
.certdoc__cap b{display:block;font-family:var(--ff-display);font-size:16px;font-weight:600;color:var(--navy)}
.certdoc__cap span{font-size:12px;color:var(--muted)}
.certdoc__view{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:7px;background:var(--red);color:#fff;font-family:var(--ff-head);font-weight:600;font-size:11px;padding:7px 11px;border-radius:3px;opacity:0;transform:translateY(-4px);transition:.25s var(--ease)}
.certdoc:hover .certdoc__view{opacity:1;transform:none}
@media(max-width:980px){.certgal{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.certgal{grid-template-columns:repeat(2,1fr)}}

/* ---------- Sectors — modern image cards with chips ---------- */
.sec-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.sec-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.35s var(--ease)}
.sec-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.sec-card__media{position:relative;aspect-ratio:16/9;overflow:hidden}
.sec-card__media img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.sec-card:hover .sec-card__media img{transform:scale(1.07)}
.sec-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,34,64,.94),rgba(10,34,64,.15) 72%)}
.sec-card__no{position:absolute;top:14px;left:20px;z-index:2;font-family:var(--ff-display);font-size:44px;font-weight:700;color:rgba(255,255,255,.55);line-height:1}
.sec-card__name{position:absolute;left:22px;right:22px;bottom:18px;z-index:2;font-family:var(--ff-display);font-size:clamp(22px,2.4vw,28px);font-weight:600;color:#fff;text-transform:uppercase;line-height:1.05}
.sec-card__body{padding:22px 24px 26px;display:flex;flex-wrap:wrap;gap:9px;align-content:flex-start;flex:1}
.sec-chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg-alt);border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:13.5px;color:var(--ink);transition:.2s}
.sec-chip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);flex:0 0 auto}
.sec-card:hover .sec-chip{border-color:#cfe0f5}
.sec-card--wide{grid-column:span 2}
@media(max-width:860px){.sec-grid{grid-template-columns:1fr}.sec-card--wide{grid-column:auto}}

/* ---------- NDT methods — alternating image/text rows ---------- */
.ndt-list{display:flex;flex-direction:column}
.ndt-method{display:grid;grid-template-columns:340px 1fr;gap:clamp(26px,3.5vw,52px);align-items:center;padding:clamp(26px,3.4vw,44px) 0;border-bottom:1px solid var(--line)}
.ndt-method:last-child{border-bottom:0}
.ndt-method:nth-child(even) .ndt-method__media{order:2}
.ndt-method__media{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
.ndt-method__media img{width:100%;height:100%;object-fit:cover}
.ndt-method__media--icon{background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;color:#fff}
.ndt-method__media--icon i{font-size:56px;opacity:.92}
.ndt-method__no{position:absolute;top:12px;left:14px;font-family:var(--ff-display);font-size:26px;font-weight:700;color:#fff;background:rgba(10,34,64,.55);padding:2px 13px;border-radius:6px;line-height:1.3}
.ndt-method h3{font-family:var(--ff-display);font-size:clamp(22px,2.3vw,27px);font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.01em;margin-bottom:12px}
.ndt-method p{color:#445268;font-size:15.5px;line-height:1.75}
@media(max-width:760px){.ndt-method{grid-template-columns:1fr;gap:18px}.ndt-method:nth-child(even) .ndt-method__media{order:0}}

/* ---------- Numbered service list (number only — no media box) ---------- */
.numlist{display:flex;flex-direction:column}
.numitem{display:grid;grid-template-columns:clamp(64px,7vw,104px) 1fr;gap:clamp(20px,3vw,44px);align-items:start;padding:clamp(26px,3.4vw,40px) 0;border-bottom:1px solid var(--line)}
.numitem:first-child{padding-top:0}
.numitem:last-child{border-bottom:0;padding-bottom:0}
.numitem__no{font-family:var(--ff-display);font-size:clamp(42px,6vw,76px);font-weight:700;line-height:.9;color:var(--blue);letter-spacing:-.01em}
.numitem h3{font-family:var(--ff-display);font-size:clamp(22px,2.3vw,27px);font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.01em;margin-bottom:12px;padding-top:6px}
.numitem p{color:#445268;font-size:15.5px;line-height:1.75}
.numitem p+p{margin-top:12px}
@media(max-width:620px){.numitem{grid-template-columns:1fr;gap:8px}.numitem__no{font-size:40px}}
.numitem h4{font-family:var(--ff-body);font-weight:700;color:var(--navy);font-size:15px;text-transform:uppercase;letter-spacing:.03em;margin:18px 0 8px}
.olist{margin:6px 0 4px;padding:0;list-style:none;counter-reset:o}
.olist li{position:relative;padding-left:28px;color:#445268;font-size:15.5px;line-height:1.7;margin-bottom:7px;counter-increment:o}
.olist li::before{content:counter(o)".";position:absolute;left:0;top:0;color:var(--blue);font-weight:700;font-family:var(--ff-display);font-size:17px}
.ticks--2{column-count:2;column-gap:48px}
.ticks--2 li{break-inside:avoid}
@media(max-width:680px){.ticks--2{column-count:1}}

/* ---------- News cards ---------- */
.newsgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.newscard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.35s var(--ease);text-decoration:none}
.newscard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.newscard__media{aspect-ratio:16/10;overflow:hidden}
.newscard__media img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.newscard:hover .newscard__media img{transform:scale(1.06)}
.newscard__body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.newscard__date{font-size:13px;color:var(--blue);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.newscard__body h3{font-family:var(--ff-display);font-size:23px;font-weight:600;color:var(--navy);line-height:1.15}
.newscard__body p{color:var(--muted);font-size:15px;line-height:1.7;flex:1}
.newscard .linkarrow{margin-top:4px}
@media(max-width:760px){.newsgrid{grid-template-columns:1fr}}

/* ---------- Advanced NDT — techniques grid ---------- */
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tech-item{position:relative;display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:8px;padding:18px 22px;transition:.25s var(--ease)}
.tech-item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-left-color:var(--red)}
.tech-item__no{font-family:var(--ff-display);font-size:24px;font-weight:700;color:var(--blue);line-height:1;flex:0 0 auto;min-width:34px}
.tech-item h3{font-size:15.5px;font-weight:600;color:var(--navy);line-height:1.35;letter-spacing:0}
@media(max-width:980px){.tech-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tech-grid{grid-template-columns:1fr}}

/* Section heading accent (ported Forgex sections) */
/* base heading text -> blue */
.fx-scn-title-3:not(.has-clr-white),.fx-scn-title-3:not(.has-clr-white) *,.fx-scn-title-2:not(.has-clr-white),.fx-scn-title-2:not(.has-clr-white) *{color:#0050B5 !important;-webkit-text-fill-color:#0050B5 !important}
/* accent words -> red (after blue to win) */
.fx-scn-title-3 .pr-clr,.fx-scn-title-3 .pr-clr *,.fx-scn-title-2 .pr-clr,.fx-scn-title-2 .pr-clr *,.fx-process-1-area .fx-scn-title-3 .pr-clr,.fx-process-1-area .fx-scn-title-3 .pr-clr *{color:#F41E1E !important;-webkit-text-fill-color:#F41E1E !important}

/* ---- CTA marquee tagline ---- */
.cta-marquee{background:#F41E1E;overflow:hidden;white-space:nowrap;padding:15px 0}
.cta-marquee__track{display:inline-flex;align-items:center;gap:56px;padding-left:56px;animation:ctaMarquee 24s linear infinite;will-change:transform}
.cta-marquee:hover .cta-marquee__track{animation-play-state:paused}
.cta-marquee__track span{font-family:var(--ff-display);font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:clamp(22px,2.4vw,30px);line-height:1;color:#fff;display:inline-flex;align-items:center;gap:56px}
.cta-marquee__track span::after{content:"\2605";font-size:14px;color:rgba(255,255,255,.75)}
@keyframes ctaMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- About quality bar: blue pill holding a drawn SVG pipeline + the rotating
   badge. The band's built-in clip-path notch is locked to 72% of the full-bleed
   band and drifts away from the bar at most widths, so we drop it and let the
   bar carve its OWN curved slot via a white collar (always aligned). ---- */
.fx-video-3{clip-path:none !important;-webkit-clip-path:none !important}

.fx-about-3-quality-height{position:relative;z-index:3}
.fx-about-3-quality{position:relative;width:188px !important;background-color:#0050B5 !important;
  /* subtle blueprint dot-grid + faint diagonal hatch over the brand-blue gradient */
  background-image:
    radial-gradient(rgba(255,255,255,.14) 1.4px, transparent 1.6px),
    repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 14px),
    linear-gradient(180deg,#0a5cd0 0%,#0050B5 58%,#013f95 100%);
  background-size:22px 22px, auto, auto;
  background-position:center top, center, center;
  border-radius:16px 16px 94px 94px;display:block !important;margin-left:auto;
  box-shadow:0 0 0 12px #fff}                         /* the white collar = the curved slot/hole */
/* rotating quality badge — full bar width, seated in the rounded bottom (like the demo) */
.fx-about-3-quality{overflow:visible}
.fx-about-3-quality .icon{position:absolute;left:1%;bottom:4px;
  width:188px;height:188px;display:flex;align-items:center;justify-content:center;z-index:4}
.fx-about-3-quality .icon img{width:100%;height:100%;filter:brightness(0) invert(1)}

/* gentle scroll-in fade so the bar still has motion */
.fx-about-3-quality{transition:opacity .8s ease,transform .9s cubic-bezier(.22,1.1,.36,1);
  opacity:0;transform:translateY(-34px)}
.fx-about-3-quality.is-seated{opacity:1;transform:translateY(0)}

@media (max-width:991px){
  .fx-about-3-quality{margin:0 auto}
}
@media (prefers-reduced-motion:reduce){
  .fx-about-3-quality{transition:none;opacity:1;transform:none}
}

/* ---- Process section: compact so the pinned step content fits the viewport ---- */
@media (min-width:992px){
  .fx-process-1-area{min-height:100vh;display:flex;align-items:center;padding-top:40px !important;padding-bottom:40px !important}
  .fx-process-1-area > .fx-container-1,.fx-process-1-area > .container{width:100%}
  .fx-process-1-area .fx-scn-title-3{font-size:clamp(26px,2.9vw,42px) !important}
  .fx-process-1-scn-title{margin-bottom:16px !important}
  .fx-process-1-tabs-btn{margin-bottom:22px !important}
  .fx-process-1-area .pane-img{max-height:360px;background:#0a2240;border-radius:14px;display:flex;align-items:center;justify-content:center}
  .fx-process-1-area .pane-img img{width:100%;height:100%;max-height:360px;object-fit:contain}
  .fx-process-1-area .pane-title{font-size:clamp(20px,2vw,28px) !important;margin-bottom:10px !important}
  .fx-process-1-area .pane-disc{font-size:14.5px !important;line-height:1.55 !important}
}

/* =====================================================================
   WhatsApp floating widget (button + popup greeting) — all pages
   ===================================================================== */
.wa-widget{position:fixed;right:24px;bottom:24px;z-index:9999;font-family:var(--ff-body,system-ui,sans-serif)}
.wa-widget *{box-sizing:border-box}
.wa-ico{width:1em;height:1em;display:block;flex:0 0 auto}
.wa-fab{position:relative;width:50px;height:50px;border:none;border-radius:50%;cursor:pointer;
  background:linear-gradient(145deg,#0eec60,#61bb0c);color:#fff;font-size:25px;line-height:1;
  display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(18,140,126,.42);
  transition:transform .25s ease,box-shadow .25s ease}
.wa-fab:hover{transform:scale(1.07);box-shadow:0 16px 34px rgba(23, 218, 56, 0.55)}
.wa-fab::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25D366;z-index:-1;
  animation:waPulse 2.4s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
.wa-fab__badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
  background:#F41E1E;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 6px rgba(0,0,0,.25)}
.wa-fab__badge.is-hidden{display:none}

/* "Need help?" teaser bubble beside the button */
.wa-teaser{position:absolute;right:62px;bottom:11px;white-space:nowrap;background:#fff;color:#23303a;
  font-size:13px;font-weight:600;line-height:1.2;padding:10px 30px 10px 15px;border-radius:12px;
  box-shadow:0 12px 28px rgba(2,31,69,.22);cursor:pointer;
  opacity:0;visibility:hidden;transform:translateX(10px);transition:opacity .3s ease,transform .3s ease,visibility .3s}
.wa-teaser.is-show{opacity:1;visibility:visible;transform:translateX(0)}
.wa-teaser::after{content:"";position:absolute;right:-7px;top:50%;transform:translateY(-50%);
  border:7px solid transparent;border-left-color:#fff}
.wa-teaser__x{position:absolute;top:3px;right:5px;width:16px;height:16px;border:none;background:none;
  font-size:15px;line-height:1;color:#90a0ad;cursor:pointer;padding:0}
.wa-teaser__x:hover{color:#23303a}

.wa-popup{position:absolute;right:0;bottom:78px;width:320px;max-width:calc(100vw - 48px);
  background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 24px 60px rgba(2,31,69,.28);
  transform:translateY(16px) scale(.96);transform-origin:bottom right;opacity:0;visibility:hidden;
  transition:transform .3s cubic-bezier(.22,1.1,.36,1),opacity .25s ease,visibility .25s}
.wa-popup.is-open{transform:translateY(0) scale(1);opacity:1;visibility:visible}
.wa-popup__head{display:flex;align-items:center;gap:12px;padding:14px 14px;
  background:linear-gradient(135deg,#075E54,#128C7E);color:#fff}
.wa-popup__avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);
  display:flex;align-items:center;justify-content:center;font-size:21px;flex:0 0 auto}
.wa-popup__id{flex:1;min-width:0;line-height:1.3}
.wa-popup__id strong{display:block;font-size:15px}
.wa-popup__id small{font-size:11.5px;opacity:.9;display:flex;align-items:center;gap:6px}
.wa-dot{width:8px;height:8px;border-radius:50%;background:#4ce06a;display:inline-block;box-shadow:0 0 0 0 rgba(76,224,106,.7);animation:waLive 1.8s infinite}
@keyframes waLive{0%{box-shadow:0 0 0 0 rgba(76,224,106,.6)}70%{box-shadow:0 0 0 7px rgba(76,224,106,0)}100%{box-shadow:0 0 0 0 rgba(76,224,106,0)}}
.wa-popup__close{margin-left:auto;background:none;border:none;color:#fff;font-size:22px;line-height:1;cursor:pointer;opacity:.85;padding:0 2px}
.wa-popup__close:hover{opacity:1}
.wa-popup__body{padding:20px 16px 8px;background:#E5DDD5 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 40 L40 0' stroke='%23d9cfc4' stroke-width='1'/%3E%3C/svg%3E")}
.wa-bubble{position:relative;background:#fff;border-radius:0 12px 12px 12px;padding:12px 14px;font-size:13.5px;
  line-height:1.5;color:#23303a;box-shadow:0 1px 2px rgba(0,0,0,.12);max-width:90%}
.wa-bubble::before{content:"";position:absolute;left:-7px;top:0;border:7px solid transparent;border-top-color:#fff;border-right-color:#fff}
.wa-popup__cta{display:flex;align-items:center;justify-content:center;gap:10px;margin:8px;padding:13px;
  background:linear-gradient(145deg,#25D366,#128C7E);color:#fff;text-decoration:none;font-weight:700;font-size:14.5px;
  border-radius:12px;transition:filter .2s ease}
.wa-popup__cta:hover{filter:brightness(1.07)}
.wa-popup__cta .wa-ico{width:18px;height:18px}

@media (max-width:575px){
  .wa-widget{right:16px;bottom:16px}
  .wa-fab{width:48px;height:48px;font-size:24px}
  .wa-popup{bottom:64px}
  .wa-teaser{font-size:12.5px;right:58px}
}

/* =====================================================================
   Error pages (404 / 500 / generic)
   ===================================================================== */
.errpage{position:relative;min-height:72vh;display:flex;align-items:center;text-align:center;overflow:hidden;
  padding:110px 0;background:radial-gradient(1200px 600px at 50% -10%, #eaf2fd 0, #ffffff 60%)}
.errpage__bg{position:absolute;inset:0;z-index:0;opacity:.45;pointer-events:none;
  background:url("/assets/img/about/a3-bg-shape-1.png") center/cover no-repeat}
.errpage .container{position:relative;z-index:1;max-width:780px}
.errpage__code{font-family:var(--ff-display,'Teko',sans-serif);font-weight:700;line-height:.82;letter-spacing:-.02em;
  font-size:clamp(120px,21vw,250px);color:#0050B5;margin:0;text-shadow:0 18px 40px rgba(0,80,181,.18)}
.errpage__code span{color:#F41E1E}
.errpage__canvas{display:block;width:100%;max-width:760px;height:clamp(230px,42vw,460px);margin:0 auto -10px}
.errpage__title{font-family:var(--ff-display,'Teko',sans-serif);text-transform:uppercase;font-weight:700;
  font-size:clamp(28px,4.4vw,48px);color:#0a2240;margin:4px 0 14px;line-height:1.05}
.errpage__lead{font-size:16px;line-height:1.65;color:#4a5763;max-width:56ch;margin:0 auto 28px}
.errpage__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.errpage__links{font-size:14px;color:#6b7886;display:flex;gap:8px 18px;justify-content:center;flex-wrap:wrap;align-items:center}
.errpage__links span{font-weight:700;color:#0a2240}
.errpage__links a{color:#0050B5;text-decoration:none}
.errpage__links a:hover{text-decoration:underline}
@media (max-width:575px){ .errpage{padding:80px 0;min-height:66vh} }

/* error pages have a light background, so keep the header solid (not the
   transparent-over-hero style) for readable nav */
body.err-body .site-header{background:#fff;box-shadow:0 8px 30px -20px rgba(10,34,64,.45);padding:12px 0}
body.err-body .site-header .main-nav a,
body.err-body .site-header .header-phone b{color:var(--navy)}
body.err-body .site-header .header-phone small{color:var(--muted)}
body.err-body .site-header .nav-toggle{color:var(--navy);background:var(--bg-alt)}
body.err-body .errpage{padding-top:150px}

/* =====================================================================
   Preloader — slide-up page-open reveal with a pulsing grid loader
   ===================================================================== */
#preloader{position:fixed;left:0;top:0;height:100vh;width:100%;z-index:99999999;overflow:hidden;
  display:flex;align-items:center;justify-content:center;background:#fff;
  transition:transform 1s cubic-bezier(.55,.085,0,.99)}
#preloader.preloaded{transform:translateY(-100%);border-radius:0 0 1000px 1000px}
#preloader .ht-loader{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;
  font-family:'Roboto',system-ui,sans-serif}
#preloader .ht-loader-cap{position:absolute;bottom:14%;left:0;right:0;text-align:center;font-size:11px;
  letter-spacing:.4em;text-transform:uppercase;color:#0050B5;font-weight:600;opacity:.75}
.ht-loader--grid .g{display:grid;grid-template-columns:repeat(3,16px);grid-gap:6px}
.ht-loader--grid .g span{width:16px;height:16px;background:#0050B5;border-radius:3px;animation:htGrid 1.2s ease-in-out infinite}
.ht-loader--grid .g span:nth-child(1){animation-delay:0s}
.ht-loader--grid .g span:nth-child(2){animation-delay:.1s}
.ht-loader--grid .g span:nth-child(3){animation-delay:.2s}
.ht-loader--grid .g span:nth-child(4){animation-delay:.1s}
.ht-loader--grid .g span:nth-child(5){animation-delay:.2s;background:#F41E1E}
.ht-loader--grid .g span:nth-child(6){animation-delay:.3s}
.ht-loader--grid .g span:nth-child(7){animation-delay:.2s}
.ht-loader--grid .g span:nth-child(8){animation-delay:.3s}
.ht-loader--grid .g span:nth-child(9){animation-delay:.4s}
@keyframes htGrid{0%,100%{transform:scale(.5);opacity:.3}50%{transform:scale(1);opacity:1}}
@media (prefers-reduced-motion:reduce){
  #preloader{transition:opacity .4s ease}
  #preloader.preloaded{transform:none;opacity:0;border-radius:0}
  .ht-loader--grid .g span{animation:none;opacity:.7}
}

/* =====================================================================
   Social media bar — docked to the left edge, expand / collapse
   ===================================================================== */
.socbar{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:9998;display:flex;align-items:center;
  transition:transform .38s cubic-bezier(.4,0,.2,1)}
.socbar *{box-sizing:border-box}
.socbar__rail{display:flex;flex-direction:column;border-radius:0 6px 6px 0;overflow:hidden;
  box-shadow:6px 8px 26px rgba(1,31,69,.22)}
.socbar__link{width:38px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;
  text-decoration:none;transition:filter .2s ease,transform .2s ease}
.socbar__link svg{width:16px;height:16px}
.socbar__link:hover{filter:brightness(1.12)}
.socbar__link--fb{background:#1877F2}
.socbar__link--li{background:#0A66C2}
.socbar__link--x{background:#000000}
.socbar__link--ig{background:radial-gradient(circle at 30% 107%,#fdf497 0,#fd5949 45%,#d6249f 60%,#285AEB 90%)}
.socbar__toggle{width:18px;height:46px;border:none;cursor:pointer;color:#fff;
  background:#013f95;border-radius:0 7px 7px 0;display:flex;align-items:center;justify-content:center;
  box-shadow:6px 6px 18px rgba(1,31,69,.20)}
.socbar__toggle svg{width:12px;height:12px;transition:transform .38s ease}
/* collapsed: slide the rail off the left edge, leaving just the toggle tab */
.socbar.is-collapsed{transform:translateY(-50%) translateX(-38px)}
.socbar.is-collapsed .socbar__toggle svg{transform:rotate(180deg)}
@media (max-width:575px){
  .socbar__link{width:36px;height:38px}
  .socbar.is-collapsed{transform:translateY(-50%) translateX(-36px)}
}

/* =====================================================================
   Home "Selected Inspection Projects" — mobile layout fix
   (the Forgex layout overlaps a 550px blurred image, a -245px card and a
    separate absolute section bg, which detaches on small screens)
   ===================================================================== */
@media (max-width:767px){
  .fx-project-2-area{padding-top:60px !important;padding-bottom:60px !important}
  .fx-project-2-slider-item{padding-bottom:0}
  .fx-project-2-slider-item .item-img{height:230px}
  .fx-project-2-slider-item .item-img img{filter:none !important}
  .fx-project-2-slider-item:is(.has-project-3) .fx-project-2-slider-item-box{
    margin:-46px 14px 0 14px !important;max-width:none !important;
    transform:none !important;opacity:1 !important;padding:26px 22px !important}
  .fx-project-2-slider-item:is(.has-project-3) .fx-project-2-slider-item-box .title{max-width:none}
  .fx-project-2-bg{display:none !important}          /* drop the detached background strip */
  .fx-project-2-slider-btn{color:var(--navy)}
}

/* detail-page content sub-headings (faithful to live bold headings) */
.prose .prose__h{font-family:var(--ff-display,'Teko',sans-serif);font-weight:600;color:#0a2240;
  font-size:clamp(19px,2.2vw,26px);line-height:1.2;margin:26px 0 8px}
.prose .prose__h:first-child{margin-top:0}

/* service scope card grid (creative list layout) */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px;margin:18px 0 10px}
.feat-card{display:flex;align-items:flex-start;gap:12px;padding:15px 16px;background:#fff;
  border:1px solid #e6edf5;border-radius:12px;box-shadow:0 10px 26px -20px rgba(10,34,64,.45);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.feat-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px -18px rgba(0,80,181,.4);border-color:#bcd6f4}
.feat-card__ic{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:#eaf2fd;color:#0050B5;
  display:flex;align-items:center;justify-content:center;font-size:13px}
.feat-card__t{font-size:14.5px;line-height:1.45;color:#2a3744;font-weight:500}
@media (max-width:575px){.feat-grid{grid-template-columns:1fr}}

/* contact form status message */
.form-status{margin-top:16px;font-size:14.5px;font-weight:500;padding:0;min-height:1px;transition:all .2s}
.form-status.is-sending{color:#0050B5}
.form-status.is-ok{color:#0a7d33;background:#e9f7ee;border:1px solid #b9e3c6;border-radius:10px;padding:12px 14px}
.form-status.is-err{color:#b32020;background:#fdeaea;border:1px solid #f3c2c2;border-radius:10px;padding:12px 14px}

/* "Hi-Tech" wordmark cropped from the logo, used inline in the heading (pixel-perfect, any browser) */
.section-title.has-logo .logo-word{
  display:inline-block;
  height:.78em;            /* match the cap height of the heading text */
  width:auto;
  vertical-align:baseline;
  margin-bottom:-.04em;    /* seat the letters on the text baseline */
}

/* ===== Lifting page: accessories callout + equipment grid (replaces the long list) ===== */
.equip-feature{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid #e7edf4;border-left:4px solid var(--blue);border-radius:14px;padding:22px 24px;margin-bottom:26px;box-shadow:0 8px 24px rgba(10,34,64,.05)}
.equip-feature__icon{flex:none;width:48px;height:48px;border-radius:12px;background:rgba(0,80,181,.10);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:20px}
.equip-feature__body h3{margin:3px 0 12px;font-size:20px;color:#0a2240;font-weight:700}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-block;padding:6px 13px;border-radius:999px;background:#eef3fa;color:#26415e;font-size:13.5px;font-weight:500;border:1px solid #e0e8f3}
.equip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.equip-card{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid #e7edf4;border-radius:12px;padding:15px 16px;font-size:14.5px;line-height:1.5;color:#26415e;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.equip-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(10,34,64,.10);border-color:#cfe0f3}
.equip-card i{color:var(--blue);font-size:16px;margin-top:2px;flex:none}
@media(max-width:560px){.equip-grid{grid-template-columns:1fr}.equip-feature{flex-direction:column;gap:12px}}

/* ===== News article: meta, inline images, comments ===== */
.article-meta{display:flex;flex-wrap:wrap;gap:10px 22px;margin-bottom:22px;font-size:13.5px;color:#7a8aa0}
.article-meta i{color:var(--blue);margin-right:6px}
.article-fig{margin:6px 0 24px;border-radius:14px;overflow:hidden;box-shadow:0 10px 28px rgba(10,34,64,.08)}
.article-fig img{display:block;width:100%;height:auto}
.prose h2{font-family:var(--ff-display);color:#0a2240;font-size:clamp(22px,2.4vw,28px);margin:28px 0 12px}
.comments{margin-top:50px;padding-top:34px;border-top:1px solid #e7edf4}
.comments__title{font-family:var(--ff-display);color:#0a2240;font-size:clamp(22px,2.6vw,30px);margin:0 0 6px}
.comments__note{font-size:13.5px;color:#7a8aa0;margin:0 0 22px}
.comments__note span{color:var(--red)}
.comment-form textarea,.comment-form input{width:100%;border:1px solid #d8e1ec;border-radius:10px;padding:13px 15px;font-size:14.5px;font-family:inherit;color:#1f2c3a;background:#fff;transition:border-color .15s,box-shadow .15s}
.comment-form textarea:focus,.comment-form input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,80,181,.12)}
.comment-form textarea{margin-bottom:14px;resize:vertical;min-height:120px}
.comment-form__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.comment-form .cf-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.comment-form .btn{border:0;cursor:pointer}
@media(max-width:640px){.comment-form__grid{grid-template-columns:1fr}}
.comment-save{display:flex;align-items:flex-start;gap:10px;margin:2px 0 18px;font-size:14px;color:#33414f;cursor:pointer;line-height:1.45}
.comment-save input{width:16px;height:16px;margin-top:2px;flex:none;accent-color:var(--blue);cursor:pointer}

/* ===== Published comments list ===== */
.comments__reply{font-family:var(--ff-display);color:#0a2240;font-size:clamp(20px,2.2vw,25px);margin:34px 0 6px}
.comment-list{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column;gap:18px}
.comment-item{display:flex;gap:14px;background:#fff;border:1px solid #e7edf4;border-radius:12px;padding:16px 18px;box-shadow:0 6px 18px rgba(10,34,64,.04)}
.comment-item__avatar{flex:none;width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:18px;font-weight:600}
.comment-item__body{flex:1;min-width:0}
.comment-item__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 12px;margin-bottom:5px}
.comment-item__name{font-weight:700;color:#0a2240;font-size:15px}
.comment-item__name a{color:#0a2240;text-decoration:none}
.comment-item__name a:hover{color:var(--blue)}
.comment-item__date{font-size:12.5px;color:#94a3b5}
.comment-item__text{color:#33414f;font-size:14.5px;line-height:1.6;word-wrap:break-word}

/* Hero: stay fully visible on short / display-scaled viewports */
@media (max-height: 780px){
  .hero{padding-top:clamp(84px,10vw,100px)}
  .hero h1{font-size:clamp(30px,4.4vw,52px)}
  .hero__lead{margin-top:16px}
  .hero__actions{margin-top:24px}
  .hero__dots{margin-top:20px}
  .hero__badge{bottom:26px}
}

/* Auto-hide header on scroll-down; slides back in on scroll-up */
.site-header.is-hidden{transform:translateY(-100%)}

/* Subtle translucent button to re-open the collapsed header */
.header-reveal{position:fixed;top:8px;left:50%;z-index:1001;display:flex;align-items:center;justify-content:center;
  width:26px;height:26px;cursor:pointer;border-radius:50%;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(13,38,71,.30);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  color:rgba(255,255,255,.85);font-size:10px;
  box-shadow:0 3px 10px -4px rgba(10,34,64,.45);
  transform:translateX(-50%) translateY(-180%) scale(.6);opacity:0;pointer-events:none;
  transition:transform .4s var(--ease),opacity .3s,background .25s,border-color .25s,color .25s}
.header-reveal i{line-height:1}
.header-reveal:hover{background:rgba(0,80,181,.9);border-color:transparent;color:#fff}
.site-header.is-hidden ~ .header-reveal{transform:translateX(-50%) translateY(0) scale(1);opacity:.7;pointer-events:auto}
.site-header.is-hidden ~ .header-reveal:hover{opacity:1}
