/*
Theme Name: TSP Steelwork Solutions
Theme URI: https://www.tspmidlands.com/
Author: OpenAI / ChatGPT
Description: A bespoke industrial WordPress theme for TSP Steelwork Solutions, based on the approved website mockup. Uses the original TSP logo asset without changing the T shape.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: tsp-steelwork
*/

:root{
  --tsp-orange:#f2a900;
  --tsp-orange-dark:#d88d00;
  --tsp-charcoal:#171717;
  --tsp-charcoal-2:#232323;
  --tsp-grey:#5f5f5f;
  --tsp-light:#f6f6f6;
  --tsp-white:#ffffff;
  --tsp-border:rgba(255,255,255,.16);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:#222;background:#fff;line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(var(--max),calc(100% - 40px));margin:0 auto}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--tsp-orange);color:#111;font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:.02em;padding:14px 20px;border:2px solid var(--tsp-orange);transition:.2s ease}
.btn:hover{background:var(--tsp-orange-dark);border-color:var(--tsp-orange-dark)}
.btn.btn-outline{background:rgba(0,0,0,.22);color:#fff;border-color:rgba(255,255,255,.65)}
.btn.btn-outline:hover{background:#fff;color:#111}
.section-kicker{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:14px;margin:0 0 4px;text-align:center}.section-title{font-size:34px;line-height:1.1;margin:0 0 28px;text-align:center}.orange{color:var(--tsp-orange)}
.site-header{position:sticky;top:0;z-index:50;background:rgba(20,20,20,.96);box-shadow:0 4px 20px rgba(0,0,0,.25)}
.header-inner{height:88px;display:flex;align-items:center;justify-content:space-between;gap:24px}.site-logo img{width:205px;max-height:68px;object-fit:contain}.main-nav ul{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}.main-nav a{color:#fff;font-size:13px;font-weight:800;text-transform:uppercase}.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--tsp-orange)}.mobile-menu-toggle{display:none;background:none;border:1px solid var(--tsp-border);color:#fff;padding:10px 12px;font-weight:700}.header-quote{white-space:nowrap}
.hero{position:relative;min-height:620px;background:linear-gradient(90deg,rgba(0,0,0,.64),rgba(0,0,0,.24),rgba(0,0,0,.04)),var(--hero) center/cover no-repeat;display:flex;align-items:center;color:#fff;overflow:hidden}.hero:after{content:"";position:absolute;inset:auto 0 0;height:90px;background:linear-gradient(transparent,rgba(0,0,0,.58))}.hero-content{position:relative;z-index:2;width:100%;max-width:none;margin:0;padding:70px 0 70px 46px}.hero-panel{position:relative;width:min(720px,52vw);background:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.58),rgba(0,0,0,.18));border-left:5px solid var(--tsp-orange);padding:42px 44px 40px 44px;backdrop-filter:blur(1.5px);box-shadow:none}.hero h1{font-size:58px;line-height:.98;margin:8px 0 18px;color:#fff;max-width:640px}.hero .eyebrow{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;letter-spacing:.06em}.hero p{font-size:18px;margin:0 0 26px;max-width:560px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.trust-strip{background:linear-gradient(180deg,#202020,#151515);color:#fff;border-top:1px solid var(--tsp-border);border-bottom:1px solid rgba(0,0,0,.35)}.trust-grid{display:grid;grid-template-columns:repeat(5,1fr)}.trust-item{padding:22px 20px;border-left:1px solid var(--tsp-border);display:flex;align-items:center;gap:12px;min-height:78px}.trust-item:last-child{border-right:1px solid var(--tsp-border)}.trust-icon{color:var(--tsp-orange);font-size:26px}.trust-item strong{display:block;font-size:13px;line-height:1.25;text-transform:uppercase}
.services{padding:58px 0 50px;background:#fff}.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{position:relative;min-height:295px;color:#fff;overflow:hidden;background:#111}.service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.35s}.service-card:hover img{transform:scale(1.05)}.service-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,.88))}.service-card-content{position:absolute;z-index:2;left:22px;right:22px;bottom:22px}.service-icon{display:inline-flex;background:var(--tsp-orange);color:#111;width:42px;height:42px;align-items:center;justify-content:center;font-size:22px;margin-bottom:15px}.service-card h3{margin:0 0 6px;font-size:18px;text-transform:uppercase}.service-card p{margin:0 0 14px;font-size:14px}.learn-more{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;font-size:13px}
.projects{padding:34px 0;background:#171717;color:#fff}.projects-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:20px}.projects-head .section-kicker,.projects-head .section-title{text-align:left;margin:0}.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.project-card{border:1px solid var(--tsp-border);background:#202020}.project-card img{height:195px;width:100%;object-fit:cover}.project-card-body{padding:18px}.project-card h3{font-size:20px;margin:0 0 4px}.project-meta{color:#ddd;font-size:13px;border-bottom:1px solid var(--tsp-border);padding-bottom:10px;margin-bottom:10px}.project-meta span{color:var(--tsp-orange);font-weight:800}.project-card p{font-size:14px;margin:0 0 12px}
.about{padding:62px 0;background:#f7f7f7}.about-grid{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:38px;align-items:center}.about-logo{max-width:300px;margin-bottom:18px}.about-image{height:170px;object-fit:cover;width:100%}.about-text h2{font-size:32px;line-height:1.1;margin:0 0 16px}.about-text .section-kicker{text-align:left}.feature-list{border-left:1px solid #ddd;padding-left:28px}.feature{display:grid;grid-template-columns:44px 1fr;gap:14px;margin:0 0 20px}.feature-icon{background:#222;color:var(--tsp-orange);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:20px}.feature h4{margin:0 0 3px;color:var(--tsp-orange);text-transform:uppercase}.feature p{margin:0;font-size:14px}
.upload{background:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.72)),url('assets/images/industrial-interior.jpg') center/cover no-repeat;color:#fff;padding:46px 0}.upload-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:34px}.upload h2{font-size:38px;margin:0 0 8px}.file-types{border:1px dashed rgba(255,255,255,.55);display:grid;grid-template-columns:repeat(4,1fr);text-align:center}.file-type{padding:18px 10px;border-left:1px dashed rgba(255,255,255,.22)}.file-type:first-child{border-left:0}.file-type strong{display:block;color:#fff}.upload-actions{margin-top:22px;display:flex;gap:18px;align-items:center;flex-wrap:wrap}.email-link{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;font-size:13px;text-decoration:underline}
.site-footer{background:#151515;color:#fff;padding:36px 0 18px}.footer-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:30px}.footer-logo{width:190px;margin-bottom:14px}.footer-col h4{color:#fff;text-transform:uppercase;font-size:13px;margin:0 0 12px}.footer-col p,.footer-col li{font-size:14px;color:#d8d8d8}.footer-col ul{list-style:none;margin:0;padding:0}.footer-col li{margin:6px 0}.footer-bottom{border-top:1px solid var(--tsp-border);margin-top:26px;padding-top:16px;color:#aaa;font-size:13px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.page-hero{background:#222;color:#fff;padding:72px 0}.page-hero h1{font-size:46px;margin:0}.content-area{padding:52px 0}.content-area p{font-size:17px}.content-area a{color:var(--tsp-orange);font-weight:700}
@media(max-width:960px){.header-inner{height:auto;padding:16px 0;flex-wrap:wrap}.mobile-menu-toggle{display:block}.main-nav{display:none;width:100%}.main-nav.is-open{display:block}.main-nav ul{display:block}.main-nav li{border-top:1px solid var(--tsp-border)}.main-nav a{display:block;padding:13px 0}.header-quote{display:none}.hero{min-height:540px}.hero-content{padding:56px 24px}.hero-panel{width:min(680px,92vw)}.hero h1{font-size:40px}.trust-grid,.service-grid,.project-grid,.about-grid,.upload-grid,.footer-grid{grid-template-columns:1fr 1fr}.trust-item{border-right:0}.about-grid{align-items:start}.feature-list{grid-column:1/-1;border-left:0;padding-left:0}}
@media(max-width:640px){.container{width:min(var(--max),calc(100% - 26px))}.site-logo img{width:170px}.hero{min-height:560px}.hero-content{padding:38px 14px}.hero h1{font-size:34px}.hero-panel{width:100%;padding:26px 24px}.trust-grid,.service-grid,.project-grid,.about-grid,.upload-grid,.footer-grid,.file-types{grid-template-columns:1fr}.projects-head{display:block}.projects-head .btn{margin-top:16px}.section-title{font-size:28px}.upload h2{font-size:30px}.file-type{border-left:0;border-top:1px dashed rgba(255,255,255,.22)}.file-type:first-child{border-top:0}}

/* Certifications page */
.cert-hero{position:relative;min-height:430px;background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.38),rgba(0,0,0,.08)),var(--cert-hero) center/cover no-repeat;color:#fff;display:flex;align-items:center;padding:70px 0 70px 46px;overflow:hidden}
.cert-hero:after{content:"";position:absolute;inset:auto 0 0;height:80px;background:linear-gradient(transparent,rgba(0,0,0,.55))}
.cert-hero-panel{position:relative;z-index:2;width:min(700px,56vw);background:linear-gradient(90deg,rgba(0,0,0,.82),rgba(0,0,0,.58),rgba(0,0,0,.12));border-left:5px solid var(--tsp-orange);padding:42px 44px;backdrop-filter:blur(1.5px)}
.cert-hero .eyebrow{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}
.cert-hero h1{font-size:58px;line-height:.98;margin:0 0 18px;color:#fff}
.cert-hero p{font-size:18px;margin:0;max-width:590px}
.cert-intro{padding:58px 0 42px;background:#fff}
.cert-intro-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.cert-left{text-align:left!important}
.cert-intro h2{font-size:38px;line-height:1.08;margin:0;color:#191919}
.cert-intro-copy{font-size:17px;color:#333}.cert-intro-copy p:first-child{margin-top:0}
.cert-cards-section{background:#f5f5f5;padding:18px 0 64px}.cert-cards{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:20px}
.cert-card{background:#191919;color:#fff;padding:32px;border:1px solid rgba(0,0,0,.08);position:relative;min-height:270px;box-shadow:0 14px 34px rgba(0,0,0,.13)}
.cert-card:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background:var(--tsp-orange)}
.cert-card-featured{background:linear-gradient(135deg,#101010,#2a2a2a)}
.cert-badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;height:58px;padding:0 14px;background:var(--tsp-orange);color:#111;font-size:22px;font-weight:900;margin-bottom:22px;letter-spacing:.02em}
.cert-card h3{font-size:27px;line-height:1.1;margin:0 0 12px}.cert-card p{color:#e7e7e7;margin:0 0 22px}.cert-card span{position:absolute;left:32px;bottom:26px;color:var(--tsp-orange);font-weight:900;text-transform:uppercase;font-size:12px;letter-spacing:.04em}
.cert-process{padding:66px 0;background:#fff}.cert-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.cert-step{border:1px solid #ddd;padding:28px 24px;background:#fff;transition:.2s ease}.cert-step:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.1)}.cert-step strong{display:block;color:var(--tsp-orange);font-size:34px;line-height:1;margin-bottom:18px}.cert-step h3{margin:0 0 8px;text-transform:uppercase}.cert-step p{margin:0;color:#555;font-size:15px}
.cert-cta{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.72)),url('assets/images/industrial-interior.jpg') center/cover no-repeat;color:#fff;padding:52px 0}.cert-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}.cert-cta h2{font-size:36px;line-height:1.08;margin:0 0 10px}.cert-cta p{margin:0;max-width:680px;color:#e6e6e6}.cert-cta .section-kicker{margin-bottom:8px}
@media(max-width:960px){.cert-hero{padding:56px 24px}.cert-hero-panel{width:min(680px,92vw)}.cert-hero h1{font-size:44px}.cert-intro-grid,.cert-cards{grid-template-columns:1fr}.cert-process-grid{grid-template-columns:1fr 1fr}.cert-cta-inner{display:block}.cert-cta .btn{margin-top:22px}}
@media(max-width:640px){.cert-hero{min-height:390px;padding:38px 14px}.cert-hero-panel{width:100%;padding:28px 24px}.cert-hero h1{font-size:36px}.cert-intro h2,.cert-cta h2{font-size:30px}.cert-process-grid{grid-template-columns:1fr}.cert-card{padding:26px}.cert-card span{position:static;display:block;margin-top:16px}}

/* Services page */
.services-hero{position:relative;min-height:500px;background:linear-gradient(90deg,rgba(0,0,0,.76),rgba(0,0,0,.38),rgba(0,0,0,.08)),var(--services-hero) center/cover no-repeat;color:#fff;display:flex;align-items:center;padding:70px 0 70px 46px;overflow:hidden}
.services-hero:after{content:"";position:absolute;inset:auto 0 0;height:86px;background:linear-gradient(transparent,rgba(0,0,0,.58))}
.services-hero-panel{position:relative;z-index:2;width:min(760px,58vw);background:linear-gradient(90deg,rgba(0,0,0,.84),rgba(0,0,0,.6),rgba(0,0,0,.14));border-left:5px solid var(--tsp-orange);padding:42px 44px 40px;backdrop-filter:blur(1.5px)}
.services-hero .eyebrow{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}
.services-hero h1{font-size:58px;line-height:.98;margin:0 0 18px;color:#fff}
.services-hero p{font-size:18px;margin:0 0 26px;max-width:620px}.services-hero-actions{margin-top:4px}
.services-intro{padding:58px 0 42px;background:#fff}.services-intro-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}.services-intro h2{font-size:38px;line-height:1.08;margin:0;color:#191919}.services-intro-copy{font-size:17px;color:#333}.services-intro-copy p:first-child{margin-top:0}
.services-list-section{background:#f5f5f5;padding:20px 0 66px}.services-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.services-page-card{background:#191919;color:#fff;padding:34px 30px;border:1px solid rgba(0,0,0,.08);position:relative;min-height:285px;box-shadow:0 14px 34px rgba(0,0,0,.13);overflow:hidden}.services-page-card:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background:var(--tsp-orange)}.services-page-card:after{content:"";position:absolute;right:-40px;bottom:-40px;width:130px;height:130px;border:18px solid rgba(242,169,0,.08);border-radius:50%}.services-page-icon{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;background:var(--tsp-orange);color:#111;font-size:28px;font-weight:900;margin-bottom:22px}.services-page-card h3{font-size:25px;line-height:1.1;margin:0 0 12px;text-transform:uppercase}.services-page-card p{color:#e7e7e7;margin:0;font-size:15px}
.services-feature-band{padding:62px 0;background:#fff}.services-feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}.services-feature-image img{height:380px;width:100%;object-fit:cover;box-shadow:0 16px 36px rgba(0,0,0,.14)}.services-feature-copy h2{font-size:40px;line-height:1.06;margin:0 0 16px}.services-feature-copy p{font-size:17px;color:#444;margin:0 0 24px}
.services-process{padding:66px 0;background:#171717;color:#fff}.services-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.services-process-step{border:1px solid var(--tsp-border);padding:28px 24px;background:#202020;transition:.2s ease}.services-process-step:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.22)}.services-process-step strong{display:block;color:var(--tsp-orange);font-size:34px;line-height:1;margin-bottom:18px}.services-process-step h3{margin:0 0 8px;text-transform:uppercase}.services-process-step p{margin:0;color:#ddd;font-size:15px}
.services-cta{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.72)),url('assets/images/industrial-interior.jpg') center/cover no-repeat;color:#fff;padding:52px 0}.services-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}.services-cta h2{font-size:36px;line-height:1.08;margin:0 0 10px}.services-cta p{margin:0;max-width:680px;color:#e6e6e6}.services-cta .section-kicker{margin-bottom:8px}
@media(max-width:960px){.services-hero{padding:56px 24px}.services-hero-panel{width:min(700px,92vw)}.services-hero h1{font-size:44px}.services-intro-grid,.services-feature-grid{grid-template-columns:1fr}.services-page-grid{grid-template-columns:1fr 1fr}.services-process-grid{grid-template-columns:1fr 1fr}.services-cta-inner{display:block}.services-cta .btn{margin-top:22px}}
@media(max-width:640px){.services-hero{min-height:430px;padding:38px 14px}.services-hero-panel{width:100%;padding:28px 24px}.services-hero h1{font-size:36px}.services-intro h2,.services-feature-copy h2,.services-cta h2{font-size:30px}.services-page-grid,.services-process-grid{grid-template-columns:1fr}.services-page-card{padding:26px}.services-feature-image img{height:280px}}

/* Editable Services / Certifications page content
   The hero is controlled by the page title, excerpt and featured image.
   Everything below the hero is standard WordPress editor content. */
.tsp-editable-page-content {
  background: #f6f6f6;
  padding: 58px 0 70px;
}

.tsp-editable-page-content .container > *:first-child {
  margin-top: 0;
}

.tsp-editable-page-content h2 {
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.05;
  margin: 0 0 18px;
  color: #202020;
}

.tsp-editable-page-content h3 {
  margin: 0 0 12px;
  color: #202020;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.tsp-editable-page-content p {
  color: #4e4e4e;
  line-height: 1.7;
}

.tsp-page-intro {
  margin-bottom: 32px;
  max-width: 980px;
}

.tsp-editable-card-grid {
  gap: 24px;
  margin: 24px 0;
}

.tsp-editable-page-content .services-page-card,
.tsp-editable-page-content .cert-card {
  height: 100%;
}

.tsp-editable-page-content .wp-block-buttons {
  margin-top: 24px;
}

.tsp-editable-page-content .wp-block-button.btn .wp-block-button__link,
.tsp-editable-page-content .wp-block-button .wp-block-button__link {
  background: var(--tsp-orange);
  color: #111;
  border-radius: 0;
  padding: 14px 24px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  box-shadow: none;
}

.tsp-editable-page-content .wp-block-button.btn .wp-block-button__link:hover,
.tsp-editable-page-content .wp-block-button .wp-block-button__link:hover {
  background: #111;
  color: #fff;
}

.tsp-editable-page-content .services-cta,
.tsp-editable-page-content .cert-process {
  margin-top: 42px;
}

.tsp-editor-empty {
  background: #fff;
  border-left: 6px solid var(--tsp-orange);
  padding: 34px;
  box-shadow: 0 12px 35px rgba(0,0,0,.08);
}

@media (max-width: 782px) {
  .tsp-editable-card-grid {
    display: block;
  }
  .tsp-editable-card-grid .wp-block-column {
    margin-bottom: 18px;
  }
}

/* Projects Showcase Module */
.projects-hero{
  position:relative;
  min-height:500px;
  background:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.42),rgba(0,0,0,.08)),var(--projects-hero) center/cover no-repeat;
  color:#fff;
  display:flex;
  align-items:center;
  padding:70px 0 70px 46px;
  overflow:hidden;
}
.projects-hero:after{content:"";position:absolute;inset:auto 0 0;height:90px;background:linear-gradient(transparent,rgba(0,0,0,.62));}
.projects-hero-panel{position:relative;z-index:2;width:min(760px,58vw);background:linear-gradient(90deg,rgba(0,0,0,.84),rgba(0,0,0,.62),rgba(0,0,0,.14));border-left:5px solid var(--tsp-orange);padding:42px 44px 40px;backdrop-filter:blur(1.5px)}
.projects-hero .eyebrow{color:var(--tsp-orange);font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}
.projects-hero h1{font-size:clamp(42px,5vw,66px);line-height:.98;margin:0 0 18px;color:#fff}
.projects-hero p{font-size:18px;margin:0;max-width:640px;color:#fff}
.projects-showcase-section{background:#f5f5f5;padding:60px 0 76px}.projects-section-head{max-width:900px;margin:0 0 32px}.projects-section-head h2{font-size:clamp(34px,4vw,52px);line-height:1.02;margin:4px 0 12px;color:#181818}.projects-section-head p,.projects-page-intro{color:#4b4b4b;font-size:17px}.projects-page-intro{margin-bottom:34px;max-width:980px}.tsp-projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.tsp-project-card{background:#171717;color:#fff;box-shadow:0 16px 38px rgba(0,0,0,.14);border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:100%}.tsp-project-card:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background:var(--tsp-orange);z-index:2}.tsp-project-card-image{display:block;height:235px;overflow:hidden;background:#222}.tsp-project-card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.tsp-project-card:hover .tsp-project-card-image img{transform:scale(1.05)}.tsp-project-card-body{padding:26px 28px 28px;display:flex;flex-direction:column;flex:1}.tsp-project-sector{display:inline-block;align-self:flex-start;background:var(--tsp-orange);color:#111;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;padding:7px 10px;margin-bottom:15px}.tsp-project-card h2{font-size:25px;line-height:1.08;margin:0 0 14px;color:#fff}.tsp-project-card h2 a{color:#fff;text-decoration:none}.tsp-project-card h2 a:hover{color:var(--tsp-orange)}.tsp-project-meta-row{display:flex;flex-wrap:wrap;gap:10px 16px;border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);padding:12px 0;margin-bottom:14px;color:#e6e6e6;font-size:13px;font-weight:700}.tsp-project-card p{color:#e7e7e7;font-size:15px;line-height:1.55;margin:0 0 18px}.tsp-project-link{margin-top:auto;color:var(--tsp-orange);font-weight:900;text-transform:uppercase;text-decoration:none;font-size:13px;letter-spacing:.04em}.tsp-project-link:hover{color:#fff}.tsp-pagination{margin-top:36px}.single-project-section{background:#f5f5f5;padding:66px 0}.single-project-layout{display:grid;grid-template-columns:360px 1fr;gap:42px;align-items:start}.single-project-details{background:#171717;color:#fff;border-left:5px solid var(--tsp-orange);padding:34px;box-shadow:0 16px 38px rgba(0,0,0,.14);position:sticky;top:32px}.single-project-details h2{margin:0 0 24px;color:#fff;font-size:30px}.single-project-details div{border-top:1px solid rgba(255,255,255,.15);padding:16px 0}.single-project-details strong{display:block;color:var(--tsp-orange);text-transform:uppercase;font-size:12px;letter-spacing:.06em;margin-bottom:5px}.single-project-details span{color:#fff}.single-project-details .btn{margin-top:22px}.single-project-content{background:#fff;padding:44px;box-shadow:0 14px 36px rgba(0,0,0,.08)}.single-project-content h2,.single-project-content h3{color:#181818}.single-project-content p{color:#444;line-height:1.7}
@media(max-width:1000px){.projects-hero{padding:56px 24px}.projects-hero-panel{width:min(700px,92vw)}.tsp-projects-grid{grid-template-columns:1fr 1fr}.single-project-layout{grid-template-columns:1fr}.single-project-details{position:static}}
@media(max-width:640px){.projects-hero{min-height:420px;padding:38px 14px}.projects-hero-panel{width:100%;padding:28px 24px}.tsp-projects-grid{grid-template-columns:1fr}.tsp-project-card-image{height:220px}.single-project-content{padding:28px}.single-project-details{padding:28px}}

/* Global accreditations band - editable via Pages > Footer Accreditations Band */
.tsp-global-accreditations-band{
  background:#f6f6f6;
  border-top:1px solid rgba(0,0,0,.08);
  border-bottom:1px solid rgba(0,0,0,.08);
  padding:34px 0;
}
.tsp-global-accreditations-band .section-kicker{
  margin-bottom:6px;
  text-align:center;
}
.tsp-global-accreditations-band h2{
  text-align:center;
  margin:0 0 22px;
  color:#222;
  font-size:30px;
  line-height:1.15;
}
.tsp-accreditation-logos{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:22px;
  width:100%;
  margin:0 auto;
}
.tsp-accreditation-logo{
  background:#fff;
  width:180px;
  min-height:118px;
  padding:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.tsp-accreditation-logo img{
  max-width:150px;
  max-height:78px;
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
  margin:0 auto;
}
.tsp-global-accreditations-band-wrap .wp-block-image,
.tsp-global-accreditations-band-wrap figure{
  margin:0;
}
@media(max-width:960px){
  .tsp-accreditation-logo{width:160px}
}
@media(max-width:640px){
  .tsp-accreditation-logos{gap:14px}
  .tsp-accreditation-logo{width:calc(50% - 7px);min-height:100px;padding:14px}
  .tsp-accreditation-logo img{max-width:120px;max-height:64px}
}

/* Contact page - editable via TSP Settings */
.contact-hero{
  position:relative;
  min-height:500px;
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
  padding:70px 0 70px 46px;
  color:#fff;
  overflow:hidden;
}
.contact-hero:after{content:"";position:absolute;inset:auto 0 0;height:90px;background:linear-gradient(transparent,rgba(0,0,0,.65));}
.contact-hero-panel{
  position:relative;
  z-index:2;
  width:min(780px,58vw);
  background:linear-gradient(90deg,rgba(0,0,0,.84),rgba(0,0,0,.62),rgba(0,0,0,.12));
  border-left:5px solid var(--tsp-orange);
  padding:46px 50px;
  backdrop-filter:blur(1.5px);
}
.contact-hero-panel .section-kicker{color:var(--tsp-orange);margin-bottom:10px;}
.contact-hero-panel h1{font-size:clamp(46px,5.8vw,78px);line-height:.96;margin:0 0 18px;color:#fff;}
.contact-hero-panel p{font-size:19px;line-height:1.55;color:#fff;max-width:680px;margin:0;}
.contact-main-section{background:#f5f5f5;padding:72px 0;}
.contact-layout{display:grid;grid-template-columns:420px 1fr;gap:36px;align-items:start;}
.contact-info-panel,.contact-form-panel{background:#fff;box-shadow:0 16px 40px rgba(0,0,0,.09);}
.contact-info-panel{background:#171717;color:#fff;border-left:5px solid var(--tsp-orange);padding:38px;}
.contact-info-panel .section-kicker,.contact-form-panel .section-kicker{color:var(--tsp-orange);text-align:left;margin-bottom:8px;}
.contact-info-panel h2,.contact-form-panel h2{font-size:clamp(30px,3vw,44px);line-height:1.03;margin:0 0 18px;}
.contact-info-panel h2{color:#fff;}.contact-form-panel h2{color:#181818;}
.contact-info-panel p{color:#e7e7e7;line-height:1.65;margin-bottom:28px;}
.contact-detail-list{display:grid;gap:14px;}
.contact-detail{display:flex;gap:16px;align-items:flex-start;color:#fff;text-decoration:none;border-top:1px solid rgba(255,255,255,.14);padding-top:16px;}
.contact-detail span{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--tsp-orange);color:#111;font-size:18px;font-style:normal;flex:0 0 38px;}
.contact-detail strong{display:block;color:var(--tsp-orange);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;}
.contact-detail em{display:block;color:#fff;font-style:normal;line-height:1.45;}
.contact-detail:hover em{color:var(--tsp-orange);}
.contact-form-panel{padding:38px 42px;}
.contact-form-panel p{color:#555;line-height:1.65;margin-bottom:24px;}
.tsp-demo-contact-form{display:grid;gap:18px;}
.tsp-demo-contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.tsp-demo-contact-form label{display:block;color:#222;font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.05em;}
.tsp-demo-contact-form input,.tsp-demo-contact-form textarea,
.contact-shortcode-form input,.contact-shortcode-form textarea,.contact-shortcode-form select{
  width:100%;box-sizing:border-box;margin-top:8px;border:1px solid #d8d8d8;background:#f8f8f8;color:#222;padding:14px 15px;font:inherit;border-radius:0;
}
.tsp-demo-contact-form input:focus,.tsp-demo-contact-form textarea:focus,
.contact-shortcode-form input:focus,.contact-shortcode-form textarea:focus,.contact-shortcode-form select:focus{
  outline:2px solid var(--tsp-orange);border-color:#111;background:#fff;
}
.tsp-demo-contact-form button,.contact-shortcode-form input[type=submit],.contact-shortcode-form button[type=submit]{
  display:inline-flex;width:auto;align-self:flex-start;border:0;background:var(--tsp-orange);color:#111;font-weight:900;text-transform:uppercase;letter-spacing:.04em;padding:16px 28px;cursor:pointer;
}
.tsp-demo-contact-form button:hover,.contact-shortcode-form input[type=submit]:hover,.contact-shortcode-form button[type=submit]:hover{background:#111;color:#fff;}
.form-helper{font-size:13px;color:#666;border-left:4px solid var(--tsp-orange);padding-left:14px;margin-top:18px!important;}
.contact-map-section{background:#f5f5f5;padding:0 0 72px;}
.contact-map-wrap{background:#fff;box-shadow:0 16px 40px rgba(0,0,0,.09);padding:10px;}
.contact-map-wrap iframe{display:block;width:100%;min-height:360px;border:0;}
@media(max-width:1000px){.contact-hero{padding:56px 24px}.contact-hero-panel{width:min(720px,92vw)}.contact-layout{grid-template-columns:1fr}.contact-info-panel{order:2}.contact-form-panel{order:1}}
@media(max-width:640px){.contact-hero{min-height:420px;padding:38px 14px}.contact-hero-panel{width:100%;padding:30px 24px}.contact-main-section{padding:44px 0}.contact-info-panel,.contact-form-panel{padding:28px}.tsp-demo-contact-form .form-row{grid-template-columns:1fr}}


/* TSP Contact Page - professional layout v1.2 */
.tsp-contact-page{background:#f4f4f4;overflow:hidden;}
.tsp-contact-hero{position:relative;min-height:520px;background-size:cover!important;background-position:center!important;display:flex;align-items:center;padding:76px 0 76px 46px;color:#fff;}
.tsp-contact-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:100px;background:linear-gradient(transparent,rgba(0,0,0,.66));pointer-events:none;}
.tsp-contact-hero-panel{position:relative;z-index:2;width:min(780px,58vw);background:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.64),rgba(0,0,0,.18));border-left:6px solid var(--tsp-orange,#ffd800);padding:48px 52px 46px;box-shadow:0 22px 55px rgba(0,0,0,.22);backdrop-filter:blur(1.5px);}
.tsp-contact-kicker{margin:0 0 12px!important;color:var(--tsp-orange,#ffd800)!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.11em!important;font-size:14px!important;line-height:1.2!important;text-align:left!important;}
.tsp-contact-hero-panel h1{margin:0 0 18px!important;color:#fff!important;font-size:clamp(44px,5.8vw,76px)!important;line-height:.96!important;font-weight:900!important;letter-spacing:-.035em!important;}
.tsp-contact-hero-panel p{margin:0!important;color:#fff!important;font-size:19px!important;line-height:1.6!important;max-width:660px!important;}
.tsp-contact-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;}
.tsp-contact-main{padding:76px 0;background:linear-gradient(180deg,#f7f7f7,#ededed);}
.tsp-contact-grid{display:grid;grid-template-columns:430px minmax(0,1fr);gap:34px;align-items:stretch;}
.tsp-contact-card{box-shadow:0 18px 45px rgba(0,0,0,.10);}
.tsp-contact-details-card{background:#171717;color:#fff;border-left:6px solid var(--tsp-orange,#ffd800);padding:42px 38px;}
.tsp-contact-form-card{background:#fff;padding:42px 46px;border-top:6px solid var(--tsp-orange,#ffd800);}
.tsp-contact-details-card h2,.tsp-contact-form-card h2{margin:0 0 16px!important;font-size:clamp(30px,3vw,44px)!important;line-height:1.04!important;font-weight:900!important;letter-spacing:-.025em!important;}
.tsp-contact-details-card h2{color:#fff!important;}.tsp-contact-form-card h2{color:#191919!important;}
.tsp-contact-copy{font-size:16px!important;line-height:1.68!important;margin:0 0 28px!important;color:#555!important;}
.tsp-contact-details-card .tsp-contact-copy{color:#e5e5e5!important;}
.tsp-contact-detail-list{display:grid;gap:0;margin-top:28px;}
.tsp-contact-detail{display:flex!important;gap:16px;align-items:flex-start;color:#fff!important;text-decoration:none!important;border-top:1px solid rgba(255,255,255,.15);padding:18px 0;}
.tsp-contact-detail:last-child{border-bottom:1px solid rgba(255,255,255,.15);}
.tsp-contact-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--tsp-orange,#ffd800);color:#111;font-size:20px;font-weight:900;line-height:1;flex:0 0 42px;border-radius:0;}
.tsp-contact-detail strong{display:block;color:var(--tsp-orange,#ffd800)!important;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin:0 0 5px;font-style:normal;}
.tsp-contact-detail em{display:block;color:#fff!important;font-style:normal;line-height:1.45;font-size:16px;}
.tsp-contact-detail:hover em{color:var(--tsp-orange,#ffd800)!important;}
.tsp-contact-form,.tsp-contact-shortcode-form form{display:grid;gap:18px;}
.tsp-form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.tsp-contact-form label,.tsp-contact-shortcode-form label{display:block;color:#222;font-weight:900;text-transform:uppercase;font-size:12px;letter-spacing:.06em;margin:0;}
.tsp-contact-form input,.tsp-contact-form textarea,.tsp-contact-shortcode-form input,.tsp-contact-shortcode-form textarea,.tsp-contact-shortcode-form select{width:100%;box-sizing:border-box;margin-top:8px;border:1px solid #d8d8d8;background:#f8f8f8;color:#222;padding:15px 16px;font:inherit;border-radius:0;box-shadow:none;}
.tsp-contact-form input:focus,.tsp-contact-form textarea:focus,.tsp-contact-shortcode-form input:focus,.tsp-contact-shortcode-form textarea:focus,.tsp-contact-shortcode-form select:focus{outline:2px solid var(--tsp-orange,#ffd800);border-color:#111;background:#fff;}
.tsp-contact-form button,.tsp-contact-shortcode-form input[type=submit],.tsp-contact-shortcode-form button[type=submit]{display:inline-flex!important;width:auto!important;align-self:flex-start;border:0;background:var(--tsp-orange,#ffd800);color:#111;font-weight:900;text-transform:uppercase;letter-spacing:.04em;padding:16px 28px;cursor:pointer;border-radius:0;}
.tsp-contact-form button:hover,.tsp-contact-shortcode-form input[type=submit]:hover,.tsp-contact-shortcode-form button[type=submit]:hover{background:#111;color:#fff;}
.tsp-form-helper{font-size:13px!important;color:#666!important;border-left:4px solid var(--tsp-orange,#ffd800);padding-left:14px;margin:20px 0 0!important;line-height:1.5!important;}
.tsp-contact-map-section{background:#ededed;padding:0 0 76px;}
.tsp-contact-map-wrap{background:#fff;box-shadow:0 16px 40px rgba(0,0,0,.09);padding:10px;}
.tsp-contact-map-wrap iframe{display:block;width:100%;min-height:360px;border:0;}
@media(max-width:1000px){.tsp-contact-hero{padding:56px 24px}.tsp-contact-hero-panel{width:min(720px,92vw)}.tsp-contact-grid{grid-template-columns:1fr}.tsp-contact-details-card{order:2}.tsp-contact-form-card{order:1}}
@media(max-width:640px){.tsp-contact-hero{min-height:440px;padding:38px 14px}.tsp-contact-hero-panel{width:100%;padding:30px 24px}.tsp-contact-main{padding:46px 0}.tsp-contact-details-card,.tsp-contact-form-card{padding:30px 26px}.tsp-form-row{grid-template-columns:1fr}.tsp-contact-hero-actions .btn{width:100%;justify-content:center}}


/* Contact hero alignment update - match Certifications/Services page header styling */
.tsp-contact-page .tsp-contact-hero{
  position:relative;
  min-height:560px;
  background-size:cover!important;
  background-position:center!important;
  display:flex;
  align-items:center;
  padding:72px 0 72px 46px!important;
  color:#fff;
  overflow:hidden;
}
.tsp-contact-page .tsp-contact-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.30),rgba(0,0,0,.10),rgba(0,0,0,.02));
  pointer-events:none;
  z-index:0;
}
.tsp-contact-page .tsp-contact-hero::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:96px;
  background:linear-gradient(transparent,rgba(0,0,0,.68));
  pointer-events:none;
  z-index:1;
}
.tsp-contact-page .tsp-contact-hero-panel{
  position:relative;
  z-index:2;
  width:min(820px,60vw)!important;
  margin-left:0!important;
  background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.66),rgba(0,0,0,.16))!important;
  border-left:6px solid var(--tsp-orange)!important;
  padding:50px 54px 48px!important;
  box-shadow:none!important;
  backdrop-filter:blur(1.5px);
}
.tsp-contact-page .tsp-contact-kicker{
  color:var(--tsp-orange)!important;
  font-size:15px!important;
  font-weight:900!important;
  letter-spacing:.13em!important;
  text-transform:uppercase!important;
  margin:0 0 14px!important;
  text-align:left!important;
}
.tsp-contact-page .tsp-contact-hero-panel h1{
  color:#fff!important;
  font-size:clamp(48px,6vw,86px)!important;
  line-height:.94!important;
  margin:0 0 22px!important;
  font-weight:900!important;
  letter-spacing:-.04em!important;
  max-width:760px;
}
.tsp-contact-page .tsp-contact-hero-panel p{
  color:#fff!important;
  font-size:clamp(18px,1.35vw,22px)!important;
  line-height:1.55!important;
  margin:0!important;
  max-width:720px!important;
  font-weight:500;
}
.tsp-contact-page .tsp-contact-hero-actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin-top:32px!important;
}
.tsp-contact-page .tsp-contact-hero-actions .btn{
  min-width:170px;
  justify-content:center;
}
.tsp-contact-page .tsp-contact-hero-actions .btn-outline{
  background:transparent!important;
  color:#fff!important;
  border:2px solid rgba(255,255,255,.88)!important;
}
.tsp-contact-page .tsp-contact-hero-actions .btn-outline:hover{
  background:#fff!important;
  color:#111!important;
}
@media(max-width:1000px){
  .tsp-contact-page .tsp-contact-hero{padding:58px 24px!important;min-height:500px;}
  .tsp-contact-page .tsp-contact-hero-panel{width:min(760px,92vw)!important;padding:40px 38px!important;}
}
@media(max-width:640px){
  .tsp-contact-page .tsp-contact-hero{padding:38px 14px!important;min-height:440px;}
  .tsp-contact-page .tsp-contact-hero-panel{width:100%!important;padding:30px 24px!important;}
  .tsp-contact-page .tsp-contact-hero-actions .btn{width:100%;}
}

/* Shared page hero component - used by Services, Certifications, Projects and Contact */
.tsp-standard-hero{
  position:relative;
  min-height:500px;
  background-color:#111;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  display:flex;
  align-items:center;
  padding:70px 0 70px 46px!important;
  overflow:hidden;
}
.tsp-standard-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:86px;
  background:linear-gradient(transparent,rgba(0,0,0,.58));
  pointer-events:none;
}
.tsp-standard-hero-panel{
  position:relative;
  z-index:2;
  width:min(760px,58vw);
  background:linear-gradient(90deg,rgba(0,0,0,.84),rgba(0,0,0,.60),rgba(0,0,0,.14));
  border-left:5px solid var(--tsp-orange)!important;
  padding:42px 44px 40px;
  backdrop-filter:blur(1.5px);
  box-shadow:none;
}
.tsp-standard-hero-kicker{
  color:var(--tsp-orange)!important;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin:0 0 10px;
  font-size:16px;
  line-height:1.2;
}
.tsp-standard-hero-panel h1{
  font-size:58px!important;
  line-height:.98!important;
  margin:0 0 18px!important;
  color:#fff!important;
  font-weight:900!important;
  letter-spacing:-.02em!important;
}
.tsp-standard-hero-intro{
  font-size:18px!important;
  line-height:1.6!important;
  margin:0!important;
  max-width:640px;
  color:#fff!important;
}
.tsp-standard-hero-actions{margin-top:26px;}

/* Force project showcase colours to use the main TSP orange, not the brighter yellow fallback */
.projects-hero-panel,
.tsp-project-card::before,
.single-project-details{border-color:var(--tsp-orange)!important;}
.projects-hero .eyebrow,
.projects-hero .tsp-standard-hero-kicker,
.tsp-project-card h2 a:hover,
.tsp-project-link,
.single-project-details strong{color:var(--tsp-orange)!important;}
.tsp-project-card::before,
.tsp-project-sector{background:var(--tsp-orange)!important;}

/* Contact page now inherits the same hero sizing as the other page headers */
.tsp-contact-page .tsp-standard-hero-panel h1{
  font-size:58px!important;
  line-height:.98!important;
  letter-spacing:-.02em!important;
}
.tsp-contact-page .tsp-standard-hero-kicker{color:var(--tsp-orange)!important;}
.tsp-contact-page .tsp-standard-hero-panel{border-left-color:var(--tsp-orange)!important;}

@media(max-width:960px){
  .tsp-standard-hero{padding:56px 24px!important;}
  .tsp-standard-hero-panel{width:min(700px,92vw);}
  .tsp-standard-hero-panel h1,
  .tsp-contact-page .tsp-standard-hero-panel h1{font-size:44px!important;}
}
@media(max-width:640px){
  .tsp-standard-hero{min-height:390px;padding:38px 14px!important;}
  .tsp-standard-hero-panel{width:100%;padding:28px 24px;}
  .tsp-standard-hero-panel h1,
  .tsp-contact-page .tsp-standard-hero-panel h1{font-size:36px!important;}
}


/* 2026-06 consistency fix: shared page headers use inline background image and TSP orange everywhere */
:root{ --tsp-yellow: var(--tsp-orange); }
.tsp-standard-hero.services-hero,
.tsp-standard-hero.projects-hero,
.tsp-standard-hero.cert-hero,
.tsp-standard-hero.tsp-contact-hero{
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}
.tsp-standard-hero .tsp-standard-hero-kicker,
.projects-hero .tsp-standard-hero-kicker,
.projects-hero .eyebrow,
.projects-hero-panel .eyebrow,
.tsp-project-link,
.tsp-project-card h2 a:hover,
.single-project-details strong{
  color:var(--tsp-orange)!important;
}
.projects-hero-panel,
.tsp-standard-hero-panel,
.tsp-project-card:before,
.single-project-details{
  border-color:var(--tsp-orange)!important;
}
.tsp-project-card:before,
.tsp-project-sector,
.tsp-editable-page-content .wp-block-button .wp-block-button__link{
  background:var(--tsp-orange)!important;
}

/* Certifications module - editable records from WP Admin > Certifications */
.tsp-certifications-intro-section{
  background:#fff;
  padding:64px 0 28px;
}
.tsp-certifications-intro-section h2{
  margin:0 0 14px;
  font-size:42px;
  line-height:1.08;
  color:#171717;
}
.tsp-certifications-intro-copy{
  max-width:900px;
  margin:0;
  font-size:18px;
  line-height:1.7;
  color:#555;
}
.tsp-certifications-showcase-section{
  background:#f4f4f4;
  padding:46px 0 72px;
}
.tsp-certifications-showcase{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:26px;
}
.tsp-certification-card{
  background:#171717;
  color:#fff;
  border-left:5px solid var(--tsp-orange);
  box-shadow:0 16px 36px rgba(0,0,0,.15);
  min-height:100%;
  display:flex;
  flex-direction:column;
}
.tsp-certification-logo-wrap{
  background:#fff;
  min-height:128px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.tsp-certification-logo-wrap img{
  display:block;
  max-height:78px;
  max-width:220px;
  width:auto;
  object-fit:contain;
}
.tsp-certification-logo-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  width:70px;
  height:70px;
  background:var(--tsp-orange);
  color:#111;
  font-weight:900;
  font-size:32px;
}
.tsp-certification-card-body{
  padding:28px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.tsp-certification-card h3{
  margin:0 0 12px;
  color:#fff;
  font-size:24px;
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.tsp-certification-text,
.tsp-certification-text p{
  color:#dfdfdf;
  line-height:1.65;
  margin-top:0;
}
.tsp-certification-meta{
  margin:10px 0 22px;
  display:grid;
  gap:10px;
}
.tsp-certification-meta div{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:12px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:10px;
}
.tsp-certification-meta dt{
  color:var(--tsp-orange);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.tsp-certification-meta dd{
  margin:0;
  color:#fff;
  font-weight:700;
}
.tsp-certification-link{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  background:var(--tsp-orange);
  color:#111!important;
  text-decoration:none;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding:13px 18px;
}
.tsp-certification-link:hover{
  background:#fff;
  color:#111!important;
}
.tsp-certification-note{
  margin-top:auto;
  color:var(--tsp-orange);
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.04em;
}
.tsp-certifications-admin-note{
  background:#fff;
  padding:0 0 72px;
}
.tsp-certifications-note-box{
  background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.72)),url('assets/images/industrial-interior.jpg') center/cover no-repeat;
  color:#fff;
  border-left:6px solid var(--tsp-orange);
  padding:44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
}
.tsp-certifications-note-box h2{
  color:#fff;
  margin:0 0 10px;
  font-size:34px;
}
.tsp-certifications-note-box p{
  color:#e9e9e9;
  margin:0;
  max-width:760px;
}
@media(max-width:1050px){
  .tsp-certifications-showcase{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:720px){
  .tsp-certifications-showcase{grid-template-columns:1fr;}
  .tsp-certifications-intro-section h2{font-size:34px;}
  .tsp-certification-meta div{grid-template-columns:1fr;gap:4px;}
  .tsp-certifications-note-box{display:block;padding:30px;}
  .tsp-certifications-note-box .btn{margin-top:22px;}
}


/* Homepage LinkedIn feed section */
.home-linkedin-feed{background:#fff;padding:58px 0 68px;border-top:1px solid #e6e6e6}
.home-linkedin-feed .section-kicker{text-align:center;margin-bottom:8px}
.home-linkedin-feed .section-title{text-align:center;margin-bottom:28px}
.home-linkedin-feed-box{background:#f7f7f7;border:1px solid #e0e0e0;padding:28px;box-shadow:0 14px 34px rgba(0,0,0,.08);overflow:hidden}
.home-linkedin-feed-box:empty{display:none}
.home-linkedin-feed-box iframe,.home-linkedin-feed-box embed,.home-linkedin-feed-box object{max-width:100%}
@media(max-width:640px){.home-linkedin-feed{padding:42px 0}.home-linkedin-feed-box{padding:18px}}

/* Professional Services module */
.tsp-services-showcase-section{
  background:#f4f4f4;
  padding:76px 0 86px;
}
.tsp-services-showcase-intro{
  max-width:860px;
  margin:0 auto 42px;
  text-align:center;
}
.tsp-services-showcase-intro h2{
  margin:0 0 14px;
  font-size:46px;
  line-height:1.05;
  color:#202020;
  letter-spacing:-.02em;
}
.tsp-services-showcase-intro p:not(.section-kicker){
  margin:0 auto;
  color:#555;
  font-size:18px;
  line-height:1.7;
}
.tsp-services-showcase-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}
.tsp-service-showcase-card{
  background:#111;
  color:#fff;
  box-shadow:0 18px 42px rgba(0,0,0,.16);
  display:flex;
  flex-direction:column;
  min-height:100%;
  overflow:hidden;
  border-bottom:4px solid var(--tsp-orange);
}
.tsp-service-showcase-image{
  position:relative;
  height:230px;
  background:#222;
  overflow:hidden;
}
.tsp-service-showcase-image:after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.55));
}
.tsp-service-showcase-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}
.tsp-service-showcase-card:hover .tsp-service-showcase-image img{
  transform:scale(1.06);
}
.tsp-service-showcase-icon{
  position:absolute;
  left:22px;
  bottom:18px;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  background:var(--tsp-orange);
  color:#111;
  font-size:30px;
  line-height:1;
  font-weight:900;
}
.tsp-service-showcase-body{
  padding:28px 28px 32px;
  flex:1;
}
.tsp-service-showcase-body h3{
  margin:0 0 12px;
  color:#fff;
  font-size:23px;
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.035em;
}
.tsp-service-showcase-body p{
  margin:0;
  color:#d8d8d8;
  line-height:1.65;
  font-size:15.5px;
}
.tsp-services-extra-content{
  background:#fff;
  padding:54px 0;
}
.tsp-services-extra-content .container > *:first-child{margin-top:0;}
.tsp-services-extra-content .container > *:last-child{margin-bottom:0;}
.tsp-services-quote-strip{
  background:linear-gradient(90deg,rgba(0,0,0,.92),rgba(0,0,0,.76)),url('assets/images/site-installation.jpg') center/cover no-repeat;
  color:#fff;
  padding:58px 0;
}
.tsp-services-quote-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
}
.tsp-services-quote-inner h2{
  color:#fff;
  margin:0 0 10px;
  font-size:38px;
}
.tsp-services-quote-inner p:not(.section-kicker){
  color:#e7e7e7;
  margin:0;
  max-width:760px;
}
@media(max-width:1050px){
  .tsp-services-showcase-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:720px){
  .tsp-services-showcase-section{padding:54px 0 62px;}
  .tsp-services-showcase-grid{grid-template-columns:1fr;}
  .tsp-services-showcase-intro h2{font-size:34px;}
  .tsp-services-quote-inner{display:block;}
  .tsp-services-quote-inner .btn{margin-top:24px;}
}
