/*
Theme Name: TC Professional Services
Theme URI: https://tc-group.com
Author: TC Group / TCPS
Description: Custom brochure theme for TC Professional Services built to the TCPS Website Technical Brief. Brand: TC Group orange (#FE5000), charcoal and beige. Includes custom post types for Team, Testimonials and Vacancies, a lead-capture contact form, and a Book a Call page.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: tcps
*/

:root{
  --orange:#FE5000;
  --orange-dark:#D84300;
  --charcoal:#231F20;
  --ink:#1A1718;
  --beige:#E8E2D6;
  --paper:#FFFFFF;
  --grey:#F5F4F2;
  --text:#3A3637;
  --muted:#6E6A6B;
  --line:#E3E0DC;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Poppins",system-ui,sans-serif;background:var(--paper);color:var(--text);font-size:15.5px;line-height:1.75}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
a{color:var(--orange-dark)}
img{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{color:var(--charcoal);line-height:1.18}
h1{font-size:clamp(30px,4.6vw,50px);font-weight:800;text-transform:uppercase;letter-spacing:.01em}
h2{font-size:clamp(24px,3.2vw,34px);font-weight:800;text-transform:uppercase}
h3{font-size:18px;font-weight:700}
.eyebrow{display:block;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.o{color:var(--orange)}
section{padding:78px 0}
:focus-visible{outline:3px solid var(--orange);outline-offset:2px}
.btn{display:inline-block;font-family:"Poppins";font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;cursor:pointer;padding:14px 30px;border-radius:8px;text-decoration:none;transition:transform .14s,box-shadow .14s,background .14s}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 10px 22px rgba(254,80,0,.32)}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-1px)}

/* header */
header.site-header{position:sticky;top:0;z-index:60;background:#fff;box-shadow:0 2px 14px rgba(0,0,0,.07)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo img{height:42px;width:auto}
.main-nav ul{display:flex;align-items:center;gap:4px;list-style:none}
.main-nav a{display:block;text-decoration:none;font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);padding:9px 14px;border-radius:6px}
.main-nav a:hover{color:var(--orange)}
.main-nav .current-menu-item>a,.main-nav .current_page_item>a{color:var(--orange)}
.main-nav .menu-cta>a{background:var(--orange);color:#fff;border-radius:8px;margin-left:10px;padding:12px 22px}
.main-nav .menu-cta>a:hover{background:var(--orange-dark);color:#fff}
.burger{display:none;background:none;border:none;cursor:pointer;width:44px;height:44px;border-radius:8px}
.burger span{display:block;width:22px;height:2.5px;background:var(--charcoal);margin:4.5px auto;border-radius:2px}
@media(max-width:960px){
  .burger{display:block}
  .main-nav{position:absolute;top:74px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);display:none;padding:10px 24px 20px;box-shadow:0 16px 30px rgba(0,0,0,.12)}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .main-nav a{padding:13px 14px}
  .main-nav .menu-cta>a{margin:8px 0 0;text-align:center}
}

/* heroes */
.hero{position:relative;color:#fff;padding:110px 0 100px;background:
 linear-gradient(100deg,rgba(20,16,15,.92) 0%,rgba(28,22,20,.78) 45%,rgba(35,31,32,.55) 100%),
 radial-gradient(circle at 78% 30%,rgba(254,80,0,.35),transparent 55%),
 linear-gradient(160deg,#2E2624,#1A1516 70%)}
.hero.has-image{background-size:cover;background-position:center}
.hero h1{color:#fff;max-width:21ch}
.hero h1 .o{display:block}
.hero p{max-width:62ch;margin:22px 0 8px;color:#E6E0DC;font-size:15.5px}
.hero .tagline{color:var(--orange);font-weight:700;margin:14px 0 26px;font-size:15px}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--orange)}
.hero.short{padding:88px 0 78px}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,16,15,.92) 0%,rgba(28,22,20,.75) 45%,rgba(35,31,32,.5) 100%)}
.hero .wrap{position:relative;z-index:1}

/* home */
.about-list{list-style:none;margin:20px 0}
.about-list li{padding:7px 0 7px 28px;position:relative;font-weight:600;color:var(--charcoal)}
.about-list li::before{content:"";position:absolute;left:2px;top:16px;width:11px;height:11px;background:var(--orange);border-radius:3px}
.rule{height:3px;background:var(--orange);width:64px;border:none;margin:14px 0 22px}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
@media(max-width:1020px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.svc-grid{grid-template-columns:1fr}}
.svc{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .16s,box-shadow .16s}
.svc:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(35,31,32,.12)}
.svc .ph{height:118px;position:relative;background:linear-gradient(135deg,#3A312E,#231F20)}
.svc .ph::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 25%,rgba(254,80,0,.55),transparent 60%)}
.svc .ph i{position:absolute;left:18px;bottom:-20px;width:48px;height:48px;border-radius:12px;background:var(--orange);color:#fff;font-style:normal;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 18px rgba(254,80,0,.4)}
.svc .body{padding:32px 20px 24px}
.svc h3{font-size:14.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--orange-dark);margin-bottom:10px}
.svc p{font-size:13.5px;color:var(--muted);line-height:1.7}
.dark{background:var(--charcoal);color:#D9D4D0}
.dark h2,.dark h3{color:#fff}
.prop-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:34px 0 26px}
@media(max-width:720px){.prop-grid{grid-template-columns:1fr}}
.prop{display:flex;align-items:center;gap:16px;background:#2D2829;border:1px solid #3A3435;border-radius:12px;padding:18px 20px}
.prop i{font-style:normal;width:46px;height:46px;border-radius:10px;background:rgba(254,80,0,.15);border:1.5px solid var(--orange);color:var(--orange);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.prop b{color:#fff;font-size:15px}
.managed{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
@media(max-width:860px){.managed{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.managed{grid-template-columns:1fr}}
.mg{border:1.5px solid var(--line);border-radius:12px;padding:22px;text-align:center;background:#fff}
.mg i{font-style:normal;display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;border:2px solid var(--orange);color:var(--orange);font-size:24px;margin-bottom:12px}
.mg b{display:block;color:var(--charcoal);font-size:14.5px;text-transform:uppercase;letter-spacing:.04em}
.chev{display:flex;justify-content:center;margin:50px 0 0}
.chev span{width:26px;height:26px;border-right:5px solid var(--orange);border-bottom:5px solid var(--orange);transform:rotate(45deg)}
.orange-band{background:var(--orange);color:#fff}
.orange-band h2{color:#fff}
.orange-band p{color:#FFE7DA}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
@media(max-width:720px){.why-grid{grid-template-columns:1fr}}
.why{display:flex;align-items:center;gap:18px;background:var(--charcoal);border-radius:10px;padding:16px 20px;color:#fff;font-weight:600;font-size:14.5px}
.why .num{font-weight:800;color:var(--orange);font-size:18px;flex-shrink:0}
.future{background:linear-gradient(115deg,var(--orange) 0%,#FF6A1F 60%,#FF7E33 100%);color:#fff;text-align:center}
.future h2{color:var(--charcoal)}
.future p{max-width:78ch;margin:18px auto;color:#3A2418;font-weight:500}

/* team */
.beige{background:var(--beige)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:34px 26px;margin-top:34px}
.tm .photo{width:120px;height:120px;border-radius:26px 26px 26px 6px;background:linear-gradient(160deg,var(--orange) 0%,#FF7E33 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:16px;position:relative}
.tm .photo img{width:100%;height:100%;object-fit:cover}
.tm .photo span{font-weight:800;font-size:34px;color:#fff;opacity:.95}
.tm b{display:block;color:var(--orange-dark);font-size:15.5px}
.tm .role{display:block;color:var(--charcoal);font-weight:600;font-size:13.5px;margin-bottom:8px}
.tm .role a{color:var(--charcoal);text-decoration:none}
.tm p{font-size:13px;color:var(--muted);line-height:1.7}

/* case studies */
.cs-bullets{list-style:none;margin:18px 0}
.cs-bullets li{padding:6px 0 6px 24px;position:relative}
.cs-bullets li::before{content:"";position:absolute;left:2px;top:15px;width:9px;height:9px;background:var(--orange);border-radius:50%}
.cs-bullets li b{color:var(--charcoal)}
.dark .cs-bullets li b{color:#fff}
.firmA{background:var(--orange);color:#fff;border-radius:16px;padding:42px 44px;margin-top:10px}
.firmA h2{color:#fff}.firmA h2 span{color:var(--charcoal)}
.firmA p{color:#FFE9DD;margin-top:14px}
.firmA b{color:#fff}
.cs-label{font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin:30px 0 8px}
.quote-band{background:var(--orange);color:#fff;text-align:center;padding:64px 0}
.quote-band blockquote{font-size:clamp(18px,2.6vw,26px);font-weight:600;font-style:italic;text-transform:uppercase;max-width:30ch;margin:0 auto 16px;line-height:1.4}
.quote-band cite{font-style:normal;font-size:12.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#FFD9C3}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
@media(max-width:880px){.t-grid{grid-template-columns:1fr}}
.tcard{background:#fff;border-radius:14px;overflow:hidden;border:1px solid var(--line);display:flex;flex-direction:column}
.tcard .ph{height:120px;background:linear-gradient(135deg,#4A403C,#262122);position:relative}
.tcard .ph::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(254,80,0,.5),transparent 60%)}
.tcard .ph img{width:100%;height:100%;object-fit:cover}
.tcard .body{padding:24px 22px}
.tcard h3{color:var(--orange-dark);font-size:13.5px;text-transform:uppercase;letter-spacing:.08em;text-align:center;margin-bottom:14px}
.tcard .q{font-size:13px;font-style:italic;color:var(--text)}
.tcard .who{display:block;text-align:center;color:var(--orange-dark);font-weight:700;font-size:13px;margin:14px 0 10px}
.tcard .impact{font-size:12.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:12px}
.tcard .impact b{color:var(--charcoal)}
.jd h2{font-size:20px;color:var(--charcoal);margin:34px 0 6px}
.jd h2.or{color:var(--orange)}
.jd .sub{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin:18px 0 6px}
.jd ul{list-style:none;margin:10px 0}
.jd ul li{padding:6px 0 6px 22px;position:relative;font-size:14px}
.jd ul li::before{content:"";position:absolute;left:2px;top:15px;width:8px;height:8px;background:var(--orange);border-radius:50%}

/* careers / jobs */
.open-roles{background:var(--orange);text-align:center;color:#fff}
.open-roles h2{color:var(--charcoal)}
.open-roles p{max-width:60ch;margin:14px auto 24px;color:#fff;font-weight:500}
.why-work{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:40px;text-align:center}
@media(max-width:880px){.why-work{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.why-work{grid-template-columns:1fr}}
.ww i{font-style:normal;font-size:38px;display:block;margin-bottom:14px;color:var(--orange)}
.ww b{display:block;font-size:15px;text-transform:uppercase;letter-spacing:.08em;color:var(--charcoal);margin-bottom:6px}
.ww p{font-size:13.5px;color:var(--muted)}
.life{background:linear-gradient(100deg,rgba(24,20,19,.9),rgba(35,31,32,.65)),linear-gradient(150deg,#2E2825,#1B1717 75%);color:#D9D4D0}
.life h2{color:#fff}
.job-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px;margin-top:36px}
.job{background:#fff;border:1.5px solid var(--orange);border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:6px;text-decoration:none;transition:transform .14s,box-shadow .14s}
.job:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(254,80,0,.18)}
.job b{color:var(--orange-dark);font-size:15.5px}
.job .meta{font-size:12.5px;color:var(--muted)}
.job p{font-size:12.5px;color:var(--text);margin:6px 0}
.job .foot{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:10px;margin-top:auto;font-size:12px;color:var(--muted)}
.job .foot b{color:var(--charcoal);font-size:12px}
.jobs-band{background:var(--orange);text-align:center;color:#fff;padding:54px 0}
.jobs-band h2{color:var(--charcoal)}
.jobs-band .eyebrow{color:#fff;margin-top:8px}

/* forms */
.book-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-top:36px}
@media(max-width:880px){.book-grid{grid-template-columns:1fr}}
.panelbox{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:0 16px 38px rgba(35,31,32,.08)}
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--charcoal);margin-bottom:6px}
.field .req{color:var(--orange)}
.field input,.field textarea{width:100%;font-family:"Poppins";font-size:14.5px;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--text)}
.field input:focus,.field textarea:focus{border-color:var(--orange)}
.err{display:none;font-size:12px;color:#C62814;margin-top:4px}
.field.invalid input{border-color:#C62814}
.field.invalid .err{display:block}
.thanks{background:var(--charcoal);color:#D9D4D0;border-radius:16px;padding:30px}
.thanks b{color:var(--orange);text-transform:uppercase;letter-spacing:.06em}
.hp{position:absolute !important;left:-9999px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:8px 15px;font-size:13px;font-family:"Poppins";cursor:pointer;color:var(--text)}
.chip[aria-pressed="true"]{background:var(--orange);border-color:var(--orange);color:#fff}
.slot-label{font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin:14px 0 8px}
.form-note{font-size:12.5px;color:var(--muted);margin-top:12px}

/* footer */
footer.site-footer{background:var(--charcoal);color:#B9B3B0;padding:56px 0 28px;font-size:13.5px}
footer.site-footer .logo-ft{height:40px;margin-bottom:22px}
footer.site-footer p{margin-bottom:8px}
footer.site-footer a{color:#D9D4D0;text-decoration:none}
footer.site-footer a:hover{color:var(--orange)}
.linkedin{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-weight:600;color:#fff !important}
.linkedin i{font-style:normal;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--orange);color:var(--orange);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.footer-legal{border-top:1px solid #3A3435;margin-top:30px;padding-top:20px;display:flex;flex-wrap:wrap;gap:6px 18px;font-size:12px;color:#8C8684}
.footer-legal a{color:#8C8684 !important}
.footer-legal ul{display:contents;list-style:none}

/* misc */
.entry-content p{margin-bottom:16px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
@media(prefers-reduced-motion:reduce){.btn,.svc,.job{transition:none}}
