/*
Theme Name: Monmouth IT Theme
Theme URI: https://monmouthit.co.uk/
Author: OpenAI
Author URI: https://openai.com/
Description: A custom WordPress theme for Monmouth IT with a lead-focused homepage for IT support and consultancy businesses.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: monmouth-it-theme
*/

:root{
  --bg:#050b14;
  --bg-soft:#08111d;
  --panel:#0b1320;
  --panel-2:#09111c;
  --text:#fff;
  --muted:rgba(255,255,255,.82);
  --muted-soft:rgba(255,255,255,.62);
  --accent:#d4a15d;
  --accent-dark:#b88644;
  --border:rgba(212,161,93,.22);
  --line:rgba(255,255,255,.08);
  --shadow:0 18px 60px rgba(0,0,0,.34);
  --container:1280px;
  --radius:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:linear-gradient(180deg,#050b14 0%,#07101b 100%);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem;color:var(--muted)}
h1,h2,h3,h4{margin:0 0 1rem;line-height:1.03}
ul{list-style:none;margin:0;padding:0}
.container{width:min(calc(100% - 40px),var(--container));margin:0 auto}
.site-wrap{overflow:hidden}
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase
}
.eyebrow:before{content:"";width:42px;height:2px;background:var(--accent)}

.site-header{
  position:absolute;top:0;left:0;width:100%;z-index:100;
  padding:14px 0;
  background:linear-gradient(to bottom, rgba(0,0,0,.46), rgba(0,0,0,0));
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:84px;
}
.site-branding{flex:0 0 auto}
.site-branding .custom-logo{max-height:68px;width:auto}
.main-navigation{flex:1;display:flex;justify-content:flex-end}
.primary-menu{
  display:flex;align-items:center;justify-content:flex-end;gap:18px;flex-wrap:nowrap;
}
.primary-menu>li{position:relative}
.primary-menu>li>a{
  display:block;padding:10px 6px;
  color:#fff;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;
}
.primary-menu>li.current-menu-item>a,
.primary-menu>li.current_page_item>a,
.primary-menu>li>a:hover{color:var(--accent)}
.primary-menu .sub-menu{
  display:none;position:absolute;top:100%;left:0;min-width:220px;
  background:rgba(11,19,32,.98);border:1px solid var(--border);border-radius:12px;
  padding:8px 0;box-shadow:var(--shadow);z-index:999
}
.primary-menu li:hover>.sub-menu,
.primary-menu li:focus-within>.sub-menu{display:block}
.primary-menu .sub-menu li a{
  display:block;padding:10px 16px;color:#fff;white-space:nowrap
}
.primary-menu .sub-menu li a:hover{background:rgba(212,161,93,.1);color:var(--accent)}

.menu-toggle{
  display:none;appearance:none;border:1px solid var(--border);background:rgba(255,255,255,.04);
  width:48px;height:48px;border-radius:12px;align-items:center;justify-content:center;gap:5px;flex-direction:column;
}
.menu-toggle span{display:block;width:20px;height:2px;background:#fff;border-radius:2px}

.hero-home{
  position:relative;min-height:980px;background-size:cover;background-position:center center;
  display:flex;align-items:stretch
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.86) 0%, rgba(0,0,0,.68) 29%, rgba(0,0,0,.22) 60%, rgba(0,0,0,.12) 100%);
}
.hero-grid{
  position:relative;z-index:2;width:100%;display:flex;align-items:stretch
}
.hero-panel{
  width:min(42%,540px);min-width:340px;padding:138px 8px 84px 8px;
  display:flex;flex-direction:column;justify-content:center
}
.hero-brand .custom-logo{max-height:112px;width:auto;margin-bottom:14px}
.hero-tagline{
  color:var(--accent);font-size:.84rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px
}
.hero-title{
  font-size:clamp(3.6rem,6.1vw,5.8rem);
  text-transform:uppercase;letter-spacing:-.05em;max-width:680px;margin-bottom:0; margin-left:70px
}
.hero-title span{display:block}
.hero-title .gold{color:var(--accent)}
.hero-accent-line{width:56px;height:4px;background:var(--accent);margin:24px 0 28px 70px;}
.hero-copy{font-size:1.05rem;max-width:440px;margin-bottom:26px; margin-left: 70px;}
.hero-actions{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:24px; margin-left:70px;}
.hero-button{
  display:inline-flex;align-items:center;justify-content:center;padding:17px 28px;border-radius:8px;
  background:var(--accent);color:#111;font-weight:800;text-transform:uppercase;letter-spacing:.02em
}
.hero-button:hover{background:var(--accent-dark)}
.hero-link{font-weight:700;color:#fff}
.hero-link:hover{color:var(--accent)}
.hero-phone{font-size:1.8rem;font-weight:500}
.hero-phone a:hover{color:var(--accent)}

.service-strip{
  position:relative;z-index:3;margin-top:-1px;
  background:rgba(4,10,18,.95);border-top:1px solid var(--border);border-bottom:1px solid var(--border)
}
.service-strip-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.service-item{
  padding:34px 28px 32px;text-align:center;border-right:1px solid rgba(212,161,93,.22)
}
.service-item:last-child{border-right:0}
.service-icon{
  width:72px;height:72px;margin:0 auto 18px;border-radius:50%;
  display:grid;place-items:center;color:var(--accent)
}
.service-icon .icon-image{max-width:48px;max-height:48px;object-fit:contain}
.service-icon .icon-emoji{font-size:2.5rem;line-height:1}
.service-item h3{
  font-size:1.35rem;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:10px
}
.service-item p{max-width:270px;margin:0 auto;color:var(--muted-soft)}

.brands-band{
  background:#040a12;padding:48px 0;border-bottom:1px solid var(--border)
}
.brands-band-grid{
  display:grid;grid-template-columns:minmax(260px, .9fr) minmax(0, 1.55fr);gap:30px;align-items:center
}
.brands-copy h2{
  font-size:clamp(2rem,3.6vw,3.2rem);text-transform:uppercase;letter-spacing:-.04em;color:var(--accent)
}
.brands-copy p{max-width:480px}
.brands-carousel-wrap{position:relative;display:flex;align-items:center;gap:12px}
.brands-carousel{
  overflow-x:auto;scroll-behavior:smooth;display:flex;gap:18px;padding:8px 0;scrollbar-width:none;flex:1;
}
.brands-carousel::-webkit-scrollbar{display:none}
.brand-slide{
  min-width:180px;height:96px;border:1px solid rgba(255,255,255,.08);border-radius:16px;
  background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;padding:18px
}
.brand-slide img{max-width:100%;max-height:52px;object-fit:contain;filter:grayscale(100%) brightness(1.35);opacity:.92}
.brand-fallback{font-size:1.2rem;font-weight:800;letter-spacing:.04em;color:rgba(255,255,255,.7)}
.carousel-button{
  border:1px solid var(--border);background:rgba(255,255,255,.03);color:#fff;
  width:42px;height:42px;border-radius:999px;display:grid;place-items:center;cursor:pointer;font-size:1.4rem;flex:0 0 auto
}
.carousel-button:hover{background:rgba(212,161,93,.12);color:var(--accent)}

.benefit-strip{background:#050b14;padding:34px 0 38px;border-bottom:1px solid var(--border)}
.benefit-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.benefit-item{display:flex;align-items:flex-start;gap:16px;padding:18px 22px;border-right:1px solid rgba(212,161,93,.2)}
.benefit-item:last-child{border-right:0}
.benefit-icon{
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;color:var(--accent);flex:0 0 auto
}
.benefit-icon .icon-image{max-width:42px;max-height:42px;object-fit:contain}
.benefit-icon .icon-emoji{font-size:2rem}
.benefit-copy h3{font-size:1.2rem;text-transform:uppercase;margin-bottom:8px}
.benefit-copy p{margin:0;color:var(--muted-soft)}

.footer-contact-strip{background:#050b14;padding:22px 0 28px}
.footer-contact-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  border-top:1px solid var(--border);padding-top:22px;font-size:1.08rem;color:#fff
}
.footer-contact-grid>div{display:flex;align-items:center;min-width:0}
.footer-contact-grid a:hover{color:var(--accent)}

.site-footer{
  background:#040912;padding:22px 0 36px;border-top:1px solid rgba(255,255,255,.05)
}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-grid .small{color:var(--muted-soft)}
.footer-contact{display:flex;gap:18px;flex-wrap:wrap}
.footer-contact a,.footer-contact span{color:var(--muted)}

@media (max-width: 1180px){
  .site-branding .custom-logo{max-height:58px}
  .primary-menu{gap:12px}
  .primary-menu>li>a{font-size:13px}
  .hero-panel{width:min(48%,560px)}
}

@media (max-width: 980px){
  .menu-toggle{display:flex}
  .main-navigation{
    position:absolute;top:100%;left:20px;right:20px;background:rgba(11,19,32,.98);
    border:1px solid var(--border);border-radius:16px;padding:12px 16px;display:none
  }
  .main-navigation.is-open{display:block}
  .primary-menu{flex-direction:column;align-items:flex-start;gap:4px}
  .primary-menu>li{width:100%}
  .primary-menu>li>a{padding:12px 0;width:100%}
  .primary-menu .sub-menu{
    position:static;display:block;background:transparent;border:0;box-shadow:none;padding:0 0 0 14px
  }
  .hero-home{min-height:860px;background-position:68% center}
  .hero-overlay{
    background:linear-gradient(180deg, rgba(0,0,0,.75) 0%, rgba(0,0,0,.7) 36%, rgba(0,0,0,.5) 100%)
  }
  .hero-panel{width:100%;max-width:620px;padding:132px 0 70px}
  .hero-brand .custom-logo{max-height:86px}
  .service-strip-grid,
  .benefit-grid,
  .footer-contact-grid{grid-template-columns:repeat(2,1fr)}
  .brands-band-grid{grid-template-columns:1fr}
}

@media (max-width: 640px){
  .container{width:min(calc(100% - 28px), var(--container))}
  .site-header{padding:10px 0}
  .header-inner{min-height:64px}
  .site-branding .custom-logo{max-height:46px}
  .hero-home{min-height:auto;padding-bottom:0;background-position:62% center}
  .hero-panel{min-width:0;padding:108px 0 48px}
  .hero-title{font-size:clamp(2.6rem, 14vw, 3.8rem)}
  .hero-copy{font-size:1rem}
  .hero-button{width:100%;text-align:center}
  .hero-phone{font-size:1.4rem}
  .service-strip-grid,
  .benefit-grid,
  .footer-contact-grid{grid-template-columns:1fr}
  .service-item,.benefit-item{border-right:0;border-bottom:1px solid rgba(212,161,93,.18)}
  .service-item:last-child,.benefit-item:last-child{border-bottom:0}
  .brand-slide{min-width:150px;height:82px}
  .brands-copy h2{font-size:1.8rem}
  .footer-grid,.footer-contact{flex-direction:column;align-items:flex-start}
}

.site-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 999;
    padding: 18px 0;
    background: rgba(5, 11, 20, 0.35);
    backdrop-filter: blur(6px);
    transition: all 0.3s ease;
}

.site-header.scrolled {
    padding: 10px 0;
    background: rgba(5, 11, 20, 0.92);
    box-shadow: 0 4px 18px rgba(0,0,0,0.25);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.site-branding {
    flex: 0 0 auto;
}

.brand-link {
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
}

.brand-link .custom-logo {
    max-height: 72px;
    width: auto;
    display: block;
    transition: max-height 0.3s ease;
}

.site-header.scrolled .brand-link .custom-logo {
    max-height: 52px;
}

.site-title-wrap {
    display: flex;
    flex-direction: column;
    line-height: 1;
}

.site-title {
    font-size: 42px;
    font-weight: 800;
    color: #fff;
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: font-size 0.3s ease;
}

.site-header.scrolled .site-title {
    font-size: 30px;
}

.site-tagline {
    margin-top: 6px;
    font-size: 12px;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    color: #d4a15d;
}

.main-navigation {
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-end;
}

.primary-menu {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 28px;
    margin: 0;
    padding: 0;
}

.primary-menu > li {
    position: relative;
}

.primary-menu > li > a {
    display: block;
    color: #fff;
    text-transform: uppercase;
    font-size: 15px;
    font-weight: 500;
    white-space: nowrap;
    padding: 10px 0;
}

.primary-menu > li > a:hover,
.primary-menu > li.current-menu-item > a,
.primary-menu > li.current_page_item > a {
    color: #d4a15d;
}

.primary-menu .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    padding: 10px 0;
    margin: 0;
    list-style: none;
    background: #0b1320;
    border: 1px solid rgba(212, 161, 93, 0.25);
}

.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu {
    display: block;
}

.primary-menu .sub-menu a {
    display: block;
    padding: 10px 16px;
    color: #fff;
}

.primary-menu .sub-menu a:hover {
    background: rgba(212, 161, 93, 0.12);
    color: #d4a15d;
}

@media (max-width: 1024px) {
    .site-title {
        font-size: 30px;
    }

    .brand-link .custom-logo {
        max-height: 58px;
    }

    .primary-menu {
        gap: 18px;
    }

    .primary-menu > li > a {
        font-size: 14px;
    }
}

@media (max-width: 768px) {
    .header-inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .main-navigation {
        width: 100%;
        justify-content: flex-start;
    }

    .primary-menu {
        flex-wrap: wrap;
        gap: 12px 18px;
    }

    .site-title {
        font-size: 24px;
    }

    .brand-link .custom-logo {
        max-height: 48px;
    }
}

body.home {
    padding-top: 0;
}

body:not(.home) {
    padding-top: 175px;
}


.site-branding {
    display: flex;
    align-items: center;
}

.brand-link {
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
}

.brand-link .custom-logo-link {
    display: inline-flex;
    align-items: center;
}

.brand-link .custom-logo,
.site-branding .custom-logo {
    max-height: 90px;
    width: auto;
    display: block;
    margin-top: 10px;
}

.site-title-wrap {
    display: flex;
    align-items: center;
    margin: 15px 0 0px 30px;
}

.site-title {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    letter-spacing: 1px;
    text-transform: uppercase;
    line-height: 1;
}