/*
Theme Name: TBG International
Theme URI: https://tbgi.co.uk
Author: TBG International Limited
Author URI: https://tbgi.co.uk
Description: Custom WordPress theme for TBG International Limited.
Version: 2.0.0
License: Proprietary
Text Domain: tbgi
*/
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&display=swap');
:root{--white:#fff;--bg:#f4f5f7;--border:#dfe1e6;--text-body:#3b3f47;--text-muted:#6c717b;--text-dark:#1a1d23;--navy:#2c3e6b;--navy-dark:#1e2d4f;--accent:#5a7fa8;--hero-bg:#161b28;--hero-mid:#1d2538;--card-dark:#1c2333}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text-body);-webkit-font-smoothing:antialiased;line-height:1.6}
::selection{background:var(--navy);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
textarea,input,button{font-family:'DM Sans',sans-serif}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
[id]{scroll-margin-top:80px}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .3s ease;border-bottom:1px solid transparent}
.site-nav.scrolled,.site-nav.light{background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom-color:var(--border)}
.site-nav .nav-inner{max-width:1200px;margin:0 auto;padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between}
.site-nav .logo img{height:28px;transition:filter .3s}
.site-nav .nav-links{display:flex;gap:28px;align-items:center}
.site-nav .nav-links a{font-size:14px;font-weight:400;transition:color .2s;color:var(--text-muted)}
.site-nav .nav-links a:hover,.site-nav .nav-links a.current{color:var(--navy);font-weight:600}
.site-nav.dark-nav .nav-links a{color:rgba(255,255,255,.65)}
.site-nav.dark-nav .nav-links a:hover,.site-nav.dark-nav .nav-links a.current{color:#fff}
.site-nav.scrolled .nav-links a{color:var(--text-muted)}
.site-nav.scrolled .nav-links a:hover,.site-nav.scrolled .nav-links a.current{color:var(--navy);font-weight:600}

/* PAGE HEADER */
.page-header{background:linear-gradient(135deg,var(--hero-bg),var(--hero-mid));padding-top:96px;padding-bottom:52px}
.page-header h1{font-size:34px;font-weight:700;color:#fff}
.page-header .subtitle{font-size:16px;color:rgba(255,255,255,.6);max-width:620px;line-height:1.7;margin-top:12px}

/* IMAGE PLACEHOLDER */
.img-placeholder{background:linear-gradient(135deg,#1c2333 0%,#253045 50%,#1e2d4f 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.img-placeholder .crosshatch{position:absolute;inset:0;opacity:.06;background-image:linear-gradient(45deg,rgba(255,255,255,.4) 1px,transparent 1px),linear-gradient(-45deg,rgba(255,255,255,.4) 1px,transparent 1px);background-size:20px 20px}
.img-placeholder .label-wrap{text-align:center;position:relative;z-index:1}
.img-placeholder .icon-circle{width:32px;height:32px;border:2px solid rgba(255,255,255,.2);border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center}
.img-placeholder .icon-circle .play{width:0;height:0;border-left:8px solid rgba(255,255,255,.25);border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px}
.img-placeholder span{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.25);font-weight:500}
.featured-image{width:100%;object-fit:cover}

/* TILES */
.tile{background:var(--white);border:1px solid var(--border);padding:28px;transition:box-shadow .2s,border-color .2s}
.tile.clickable:hover{box-shadow:0 2px 12px rgba(0,0,0,.07);border-color:#ccc}
.tile.dark{background:var(--card-dark);border-color:rgba(255,255,255,.06);color:rgba(255,255,255,.75)}
.tile.dark.clickable:hover{border-color:rgba(255,255,255,.15)}
.tile.no-pad{padding:0;overflow:hidden}
.tile.no-pad .featured-image,.tile.no-pad .img-placeholder{width:100%}
.tile.no-pad>div[style*="padding"]{padding:28px 36px 36px}
.tile-accent{width:28px;height:2px;margin-bottom:16px}
.tile-accent.navy{background:var(--navy)}
.tile-accent.accent{background:var(--accent)}

/* SECTIONS */
.section{padding:56px 32px}
.section.white-bg{background:var(--white)}
.section.grey-bg{background:var(--bg)}
.section.bordered-top{border-top:1px solid var(--border)}
.section.bordered-bottom{border-bottom:1px solid var(--border)}
.section-title{font-size:24px;font-weight:700;color:var(--text-dark)}
.section-subtitle{font-size:15px;color:var(--text-muted);line-height:1.7;max-width:500px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-2-wide{display:flex;gap:48px;align-items:flex-start}
.grid-2-wide>*{flex:1;margin:0!important;padding:0}
.grid-asymm{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.grid-content{display:grid;grid-template-columns:1.3fr .7fr;gap:44px}
.grid-form{display:grid;grid-template-columns:3fr 2fr;gap:24px}
.divider{width:100%;height:1px;background:var(--border);margin:40px 0}

/* HERO */
.hero{background:linear-gradient(135deg,var(--hero-bg) 0%,var(--hero-mid) 100%);padding-top:64px}
.hero h1{font-size:clamp(34px,4.5vw,52px);font-weight:700;color:#fff;line-height:1.15;max-width:680px;margin-bottom:20px}
.hero .hero-text{font-size:17px;line-height:1.75;color:rgba(255,255,255,.6);max-width:580px;margin-bottom:32px}

/* BUTTONS */
.btn{display:inline-block;padding:12px 28px;font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:opacity .2s}
.btn:hover{opacity:.9}
.btn-accent{background:var(--accent);color:#fff}
.btn-navy{background:var(--navy);color:#fff}

/* STATS */
.stat-box{padding:24px;background:var(--bg);text-align:center}
.stat-value{font-size:26px;font-weight:700;color:var(--navy)}
.stat-label{font-size:13px;color:var(--text-muted);margin-top:2px}

/* NEWS */
.news-tag{display:inline-block;font-size:11px;font-weight:600;color:var(--accent)}
.news-date{font-size:13px;color:var(--text-muted)}
.news-title{font-size:15px;font-weight:600;color:var(--text-dark);line-height:1.35;margin:8px 0 6px}
.news-featured-title{font-size:22px;font-weight:700;color:var(--text-dark);line-height:1.3;margin:8px 0 10px}
.article-body p{font-size:15px;line-height:1.85;color:var(--text-body);margin-bottom:18px}
.article-body ul,.article-body ol{font-size:15px;line-height:1.85;color:var(--text-body);margin:0 0 18px 20px}
.article-body li{margin-bottom:6px}
.article-body h2,.article-body h3,.article-body h4{color:var(--text-dark);margin:28px 0 14px 0}
.article-body h2{font-size:20px;font-weight:700}
.article-body h3{font-size:17px;font-weight:700}
.article-body h4{font-size:15px;font-weight:600}

/* CAPABILITIES */
.cap-content h2{font-size:20px;font-weight:700;color:var(--text-dark);margin:0 0 14px 0}
.cap-content h3{font-size:17px;font-weight:700;color:var(--text-dark);margin:24px 0 12px 0}
.cap-content p{font-size:15px;line-height:1.8;color:var(--text-body);margin:0 0 14px 0}
.cap-content p:last-child{margin-bottom:0}
.cap-content ul,.cap-content ol{margin:0 0 14px 20px;font-size:15px;line-height:1.8;color:var(--text-body)}
.cap-item{padding:8px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-body);display:flex;gap:10px;align-items:flex-start}
.cap-dot{width:5px;height:5px;background:var(--navy);border-radius:50%;flex-shrink:0;margin-top:7px}
.cap-sidebar{background:var(--bg);padding:28px}
.cap-sidebar-title{font-size:14px;font-weight:600;color:var(--text-dark);letter-spacing:.3px;text-transform:uppercase;margin-bottom:14px}

/* FORMS — CF7 overrides */
.wpcf7 input[type="text"],.wpcf7 input[type="email"],.wpcf7 textarea,.wpcf7 select{width:100%;padding:10px 14px;background:var(--white);border:1px solid var(--border);color:var(--text-dark);font-size:14px;outline:none;transition:border-color .2s;font-family:'DM Sans',sans-serif}
.wpcf7 input:focus,.wpcf7 textarea:focus{border-color:var(--navy)}
.wpcf7 textarea{resize:vertical}
.wpcf7 input[type="submit"]{display:inline-block;padding:12px 28px;background:var(--navy);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .2s}
.wpcf7 input[type="submit"]:hover{opacity:.9}
.wpcf7 input[type="file"]{padding:10px 0}
.wpcf7 .wpcf7-response-output{border-color:var(--navy)!important;padding:20px!important;margin:20px 0 0!important;font-size:14px}
.wpcf7 .wpcf7-not-valid-tip{font-size:13px;color:#c4550a}
.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:5px}
.form-row{margin-bottom:16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.word-count{font-weight:400;color:var(--text-muted);font-size:12px}

/* FOOTER */
.site-footer{background:var(--hero-bg);color:rgba(255,255,255,.55);padding:48px 32px 28px;font-size:14px}
.site-footer .footer-grid{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:40px}
.site-footer .footer-heading{font-weight:600;color:#fff;margin-bottom:12px;font-size:12px;letter-spacing:.5px;text-transform:uppercase}
.site-footer a{transition:color .2s}
.site-footer a:hover{color:#fff}
.site-footer .footer-bottom{margin-top:36px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;font-size:12px}
.site-footer .logo img{height:24px;margin-bottom:14px}

/* TYPOGRAPHY */
.text-body{font-size:15px;line-height:1.8;color:var(--text-body)}
.text-body+.text-body{margin-top:16px}
.text-small{font-size:14px;line-height:1.7;color:var(--text-body)}
.text-muted{color:var(--text-muted)}
.text-dark{color:var(--text-dark)}
.text-navy{color:var(--navy);font-weight:500}
.heading-lg{font-size:26px;font-weight:700;color:var(--text-dark);line-height:1.25}
.heading-md{font-size:22px;font-weight:700;color:var(--text-dark)}
.heading-sm{font-size:20px;font-weight:700;color:var(--text-dark)}
.heading-xs{font-size:17px;font-weight:700;color:var(--text-dark)}
.link-arrow{font-size:13px;font-weight:600;color:var(--navy);display:inline-block;margin-top:12px}
.back-link{font-size:14px;font-weight:600;color:var(--navy);display:inline-block;margin-bottom:24px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-14{margin-bottom:14px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-28{margin-bottom:28px}.mb-32{margin-bottom:32px}.mb-40{margin-bottom:40px}.mt-12{margin-top:12px}.mt-24{margin-top:24px}.p-28{padding:28px}.p-32{padding:32px}.p-36{padding:36px}.p-40{padding:40px}.p-48{padding:48px}

/* RESPONSIVE */
@media(max-width:900px){
  .wrap{padding:0 16px!important}
  .section{padding:36px 16px}
  .hero .wrap{padding:100px 16px 48px!important}
  .grid-2,.grid-2-wide,.grid-asymm,.grid-content,.grid-form{grid-template-columns:1fr;gap:16px}
  .grid-2-wide{flex-direction:column}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero{padding-top:0}
  .hero h1{font-size:28px;margin-bottom:16px}
  .hero .hero-text{font-size:15px;margin-bottom:20px}
  .page-header{padding-top:80px;padding-bottom:32px}
  .page-header h1{font-size:24px}
  .page-header .subtitle{font-size:14px}
  .heading-lg{font-size:22px}
  .heading-md{font-size:19px}
  .heading-sm{font-size:17px}
  .tile{padding:20px!important}
  .tile.no-pad{padding:0!important}
  .tile.no-pad>div[style*="padding"]{padding:20px!important}
  .p-48,.p-40,.p-36,.p-32,.p-28{padding:20px!important}
  .mb-40{margin-bottom:24px}
  .mb-28{margin-bottom:16px}
  .stat-box{padding:14px 10px}
  .stat-value{font-size:20px}
  .stat-label{font-size:11px}
  .cap-sidebar{padding:16px;margin-top:16px}
  .featured-image{height:200px!important}
  .img-placeholder{height:200px!important}
  .text-body{font-size:14px}
  .text-small{font-size:13px}
  .btn{padding:10px 20px;font-size:13px}
  .divider{margin:28px 0}

  /* Two-col stats grid stays 2 col on mobile */
  .grid-2.stat-grid{grid-template-columns:1fr 1fr}

  /* Nav - hamburger */
  .site-nav .nav-inner{padding:0 16px}
  .site-nav .nav-links{
    display:none;flex-direction:column;position:absolute;top:64px;left:0;right:0;
    background:rgba(255,255,255,0.98);backdrop-filter:blur(8px);
    padding:20px;gap:16px;border-bottom:1px solid var(--border);
  }
  .site-nav .nav-links.open{display:flex}
  .site-nav .nav-links a{font-size:16px;color:var(--text-dark)!important}
  .site-nav .nav-links a.current{color:var(--navy)!important}
  .site-nav .hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
  .site-nav .hamburger span{display:block;width:22px;height:2px;background:var(--text-muted);transition:background .2s}
  .site-nav.dark-nav .hamburger span{background:rgba(255,255,255,0.7)}
  .site-nav.scrolled .hamburger span{background:var(--text-muted)}

  /* Footer */
  .site-footer{padding:32px 16px 20px}
  .site-footer .footer-grid{grid-template-columns:1fr!important;gap:24px}
  .site-footer .logo img{height:20px}
  .site-footer .footer-bottom{flex-direction:column;gap:6px;font-size:11px}
  .site-footer p{font-size:13px}
}
@media(min-width:901px){
  .site-nav .hamburger{display:none}
}
