/*
Theme Name: Headway Solutions Ltd
Theme URI: https://headwaysolutions.co.uk
Author: Headway Solutions Ltd
Description: Technology and business solutions consulting theme. Clean white with violet/purple accent and soft shadow system. Full AJAX contact form, Schema.org JSON-LD, scroll animations, and auto page creation.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: headway-solutions
Tags: technology, solutions, consulting, clean, modern, white, responsive
*/
:root{
  --violet:#6D28D9;--violet-lt:#7C3AED;--violet2:#8B5CF6;--lavender:#EDE9FE;
  --lavender2:#F5F3FF;--white:#FFFFFF;--off:#FAFAFA;--text:#1E1B4B;--text-dim:#5B6A8A;
  --border:rgba(109,40,217,.14);--border-c:rgba(109,40,217,.11);--accent:var(--violet);--border-color:var(--border-c);
  --shadow:0 16px 48px rgba(109,40,217,.12);--rad:8px;--rad-lg:16px;
  --tr:all .34s cubic-bezier(.25,1,.5,1);--fw-h:'Plus Jakarta Sans',sans-serif;
  --fw-b:'Manrope',sans-serif;--max:1180px;--hh:78px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--fw-b);background:var(--white);color:var(--text);overflow-x:hidden;line-height:1.76}
img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none;transition:var(--tr)}ul{list-style:none}button,input,textarea,select{font-family:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}.section-pad{padding:96px 0}
h1,h2,h3,h4{font-family:var(--fw-h);color:var(--text);line-height:1.1;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.3rem,4.8vw,4rem)}h2{font-size:clamp(1.8rem,3.2vw,2.8rem)}h3{font-size:clamp(1.1rem,1.7vw,1.4rem)}
p{margin-bottom:1em;color:var(--text-dim)}p:last-child{margin-bottom:0}
.label-tag{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--violet);margin-bottom:14px}
.label-tag::before{content:'';width:20px;height:2px;background:linear-gradient(90deg,var(--violet),var(--violet2));border-radius:2px}
.subtitle{font-size:1.04rem;color:var(--text-dim);max-width:560px;margin-bottom:50px;line-height:1.8}
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 26px;border-radius:var(--rad-lg);font-size:.87rem;font-weight:700;font-family:var(--fw-h);letter-spacing:.02em;cursor:pointer;border:none;transition:var(--tr);white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--violet),var(--violet-lt));color:#fff;box-shadow:0 6px 22px rgba(109,40,217,.3)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(109,40,217,.4);color:#fff}
.btn-dark{background:var(--text);color:#fff}.btn-dark:hover{background:var(--violet);transform:translateY(-2px);color:#fff}
.btn-outline{background:transparent;color:var(--violet);border:2px solid var(--border)}.btn-outline:hover{background:var(--lavender);border-color:var(--violet)}
.btn-light{background:#fff;color:var(--text);font-weight:800;box-shadow:0 4px 14px rgba(0,0,0,.1)}.btn-light:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.14)}
.btn-outline-light{background:transparent;color:rgba(255,255,255,.85);border:2px solid rgba(255,255,255,.3)}.btn-outline-light:hover{background:rgba(255,255,255,.1);color:#fff}
#site-header{position:fixed;inset:0 0 auto 0;height:var(--hh);z-index:1000;transition:var(--tr)}
#site-header::before{content:'';position:absolute;inset:0;background:transparent;border-bottom:1px solid transparent;transition:var(--tr)}
#site-header.scrolled::before{background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-bottom-color:var(--border);box-shadow:0 2px 16px rgba(109,40,217,.08)}
.header-inner{height:100%;display:flex;align-items:center;justify-content:space-between;position:relative}
.site-logo{display:flex;align-items:center;gap:12px;z-index:2}
.logo-box{width:42px;height:42px;background:linear-gradient(135deg,var(--violet),var(--violet2));border-radius:var(--rad-lg);display:flex;align-items:center;justify-content:center;font-family:var(--fw-h);font-weight:800;font-size:.9rem;color:#fff;flex-shrink:0;box-shadow:0 4px 14px rgba(109,40,217,.35)}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--fw-h);font-weight:800;font-size:.96rem;color:var(--text)}
.logo-sub{font-size:.56rem;color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
.main-nav{display:flex;align-items:center;gap:2px}
.main-nav a{padding:7px 14px;font-size:.83rem;font-weight:600;color:var(--text-dim);border-radius:var(--rad-lg);transition:var(--tr)}
.main-nav a:hover,.main-nav a.current{color:var(--violet);background:var(--lavender)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:2}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--tr)}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{position:fixed;top:0;right:-100%;width:min(320px,88vw);height:100vh;background:#fff;border-left:1px solid var(--border);z-index:999;padding:86px 28px 40px;transition:right .42s cubic-bezier(.16,1,.3,1);overflow-y:auto}
.mobile-nav.open{right:0;box-shadow:var(--shadow)}.mobile-nav ul{display:flex;flex-direction:column}
.mobile-nav a{display:block;padding:14px 0;font-size:1.05rem;font-weight:700;font-family:var(--fw-h);color:var(--text);border-bottom:1px solid var(--border);transition:var(--tr)}.mobile-nav a:hover{color:var(--violet);padding-left:8px}
.mobile-nav-foot{margin-top:28px;padding-top:22px;border-top:1px solid var(--border)}.mobile-nav-foot p{font-size:.8rem;color:var(--text-dim);margin-bottom:5px}
#nav-overlay{position:fixed;inset:0;background:rgba(30,27,75,.4);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s}#nav-overlay.vis{opacity:1;pointer-events:all}
#site-loader{position:fixed;inset:0;background:var(--violet);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;transition:opacity .5s,visibility .5s}
#site-loader.gone{opacity:0;visibility:hidden}
.loader-logo{font-family:var(--fw-h);font-size:1.5rem;font-weight:800;color:#fff}.loader-logo span{color:rgba(255,255,255,.5)}
.loader-bar-wrap{width:150px;height:3px;background:rgba(255,255,255,.2);border-radius:3px;overflow:hidden}.loader-bar{height:100%;background:#fff;animation:ld 1.4s ease forwards}@keyframes ld{from{width:0}to{width:100%}}
.hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,var(--text) 0%,#2D1B69 50%,var(--violet) 100%);position:relative;overflow:hidden;padding-top:var(--hh)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 80% 50%,rgba(139,92,246,.2) 0%,transparent 60%)}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;padding:80px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--violet2);margin-bottom:18px}
.hero h1{color:#fff;margin-bottom:20px}.hero h1 em{font-style:normal;color:var(--violet2)}
.hero-sub{font-size:1.04rem;color:rgba(255,255,255,.65);line-height:1.8;max-width:480px;margin-bottom:32px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-nums{display:flex;gap:36px;margin-top:44px;padding-top:36px;border-top:1px solid rgba(255,255,255,.1)}
.num-val{font-family:var(--fw-h);font-size:2rem;font-weight:800;color:#fff;line-height:1}.num-val span{color:var(--violet2)}.num-lbl{font-size:.68rem;color:rgba(255,255,255,.4);margin-top:4px;letter-spacing:.07em;text-transform:uppercase}
.hero-card-block{background:rgba(255,255,255,.06);border:1px solid rgba(139,92,246,.25);border-radius:var(--rad-lg);padding:32px;backdrop-filter:blur(8px)}
.hero-card-item{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.07)}.hero-card-item:last-child{border-bottom:none;padding-bottom:0}
.hci-icon{width:38px;height:38px;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.25);border-radius:var(--rad);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.hci-title{font-family:var(--fw-h);font-size:.86rem;font-weight:700;color:#fff;margin-bottom:3px}.hci-text{font-size:.75rem;color:rgba(255,255,255,.5);line-height:1.6}
.services-section,.bg-light{background:var(--white)}.bg-alt{background:var(--lavender2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{background:var(--off);border:1px solid rgba(0,0,0,.06);border-radius:var(--rad-lg);padding:28px 24px;transition:var(--tr)}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--border);background:#fff}
.svc-icon{font-size:1.8rem;margin-bottom:14px}.svc-card h4{font-size:.94rem;margin-bottom:8px;color:var(--text)}.svc-card p{font-size:.83rem;color:var(--text-dim);margin:0;line-height:1.7}
.about-section{background:var(--lavender2)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-visual-inner{background:#fff;border-radius:var(--rad-lg);padding:44px;box-shadow:var(--shadow);text-align:center;border:1px solid var(--border)}
.about-icon-lg{font-size:4rem;margin-bottom:14px;display:block}
.about-text h2{margin-bottom:16px}.about-text>p{color:var(--text-dim);margin-bottom:14px}
.checklist{display:flex;flex-direction:column;gap:10px;margin:22px 0}.check-item{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text)}
.check-item::before{content:'✓';width:20px;height:20px;background:linear-gradient(135deg,var(--violet),var(--violet2));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:#fff;font-weight:700;flex-shrink:0}
.testimonials-section{background:#fff}.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.t-card{background:var(--lavender2);border:1px solid var(--border);border-radius:var(--rad-lg);padding:28px;transition:var(--tr)}.t-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.t-stars{color:#F59E0B;font-size:.8rem;letter-spacing:3px;margin-bottom:12px}.t-text{font-size:.88rem;color:var(--text-dim);line-height:1.8;font-style:italic;margin-bottom:18px}
.t-author{display:flex;align-items:center;gap:12px}
.t-avatar{width:42px;height:42px;background:linear-gradient(135deg,var(--violet),var(--violet2));border-radius:var(--rad-lg);display:flex;align-items:center;justify-content:center;font-family:var(--fw-h);font-weight:800;color:#fff;font-size:.8rem;flex-shrink:0}
.t-name{font-family:var(--fw-h);font-size:.86rem;font-weight:700;color:var(--text)}.t-role{font-size:.7rem;color:var(--text-dim);margin-top:2px}
.cta-section{background:linear-gradient(135deg,var(--text) 0%,var(--violet) 100%);padding:88px 0;text-align:center}
.cta-section h2{color:#fff;margin-bottom:12px}.cta-section p{color:rgba(255,255,255,.65);font-size:1.04rem;margin-bottom:28px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.page-hero{background:linear-gradient(135deg,var(--text),#2D1B69);padding:136px 0 68px;position:relative}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.4),transparent)}
.page-hero-inner{position:relative}.page-hero h1{color:#fff;margin-bottom:12px}.page-hero .desc{color:rgba(255,255,255,.55);font-size:1rem;max-width:540px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.73rem;color:rgba(255,255,255,.35);margin-bottom:14px}.breadcrumb a{color:var(--violet2)}.breadcrumb span{opacity:.4}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.team-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:var(--rad-lg);overflow:hidden;transition:var(--tr)}.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.team-top{height:150px;background:linear-gradient(135deg,var(--text),var(--violet));display:flex;align-items:center;justify-content:center}
.team-init{width:66px;height:66px;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fw-h);font-weight:800;font-size:1.4rem;color:#fff}
.team-body{padding:18px 20px}.team-name{font-family:var(--fw-h);font-weight:800;font-size:.96rem;margin-bottom:4px;color:var(--text)}.team-role{font-size:.7rem;color:var(--violet);font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.team-bio{font-size:.78rem;color:var(--text-dim);line-height:1.65;margin:0}
.svc-full-card{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;padding:56px 0;border-bottom:1px solid rgba(0,0,0,.07)}.svc-full-card:last-child{border-bottom:none}.svc-full-card.flip{direction:rtl}.svc-full-card.flip>*{direction:ltr}
.svc-visual{background:var(--lavender2);border-radius:var(--rad-lg);padding:48px;text-align:center;border:1px solid var(--border)}.svc-big-icon{font-size:5rem;display:block;margin-bottom:12px}
.svc-list{display:flex;flex-direction:column;gap:10px;margin:18px 0}.svc-list li{display:flex;gap:10px;font-size:.88rem;color:var(--text-dim);align-items:flex-start}.svc-list li::before{content:'→';color:var(--violet);flex-shrink:0;margin-top:1px}
.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.port-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:var(--rad-lg);overflow:hidden;transition:var(--tr)}.port-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.port-top{height:180px;background:linear-gradient(135deg,var(--text),var(--violet));display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative}
.port-badge{position:absolute;top:12px;left:12px;background:var(--violet2);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:var(--rad-lg)}
.port-body{padding:22px}.port-industry{font-size:.68rem;color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}.port-body h3{font-size:1rem;margin-bottom:8px;color:var(--text)}.port-body p{font-size:.83rem;color:var(--text-dim);margin-bottom:14px}
.port-metrics{display:flex;gap:18px;padding-top:14px;border-top:1px solid rgba(0,0,0,.06)}.pm-val{font-family:var(--fw-h);font-size:1.25rem;font-weight:800;color:var(--violet);line-height:1}.pm-lbl{font-size:.65rem;color:var(--text-dim);margin-top:3px}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
.contact-info h2{margin-bottom:12px}.contact-info>p{color:var(--text-dim);margin-bottom:28px}.c-details{display:flex;flex-direction:column;gap:16px}
.c-item{display:flex;gap:14px;align-items:flex-start}.c-icon{width:42px;height:42px;background:var(--lavender2);border:1px solid var(--border);border-radius:var(--rad-lg);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.c-lbl{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:3px}.c-val{font-size:.88rem;color:var(--text);line-height:1.5}.c-val a{color:var(--text)}.c-val a:hover{color:var(--violet)}
.form-wrap{background:#fff;border-radius:var(--rad-lg);padding:40px 36px;border:1px solid rgba(0,0,0,.07);box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:.7rem;font-weight:700;color:var(--text);letter-spacing:.05em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{background:var(--lavender2);border:2px solid var(--border);border-radius:var(--rad);padding:12px 14px;font-size:.9rem;color:var(--text);transition:var(--tr);width:100%;outline:none;resize:vertical}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--violet);background:#fff;box-shadow:0 0 0 4px rgba(109,40,217,.07)}
.form-group textarea{min-height:120px}#submit-btn{width:100%;justify-content:center;padding:14px}
.form-status{text-align:center;padding:13px;border-radius:var(--rad);font-size:.86rem;font-weight:600;display:none;margin-top:12px}
.form-status.ok{display:block;background:rgba(109,40,217,.06);color:var(--violet);border:1px solid rgba(109,40,217,.2)}.form-status.err{display:block;background:rgba(239,68,68,.06);color:#dc2626;border:1px solid rgba(239,68,68,.15)}
#site-footer{background:var(--text);color:rgba(255,255,255,.5);padding:68px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-desc{font-size:.83rem;line-height:1.8;margin:12px 0 20px;max-width:255px}.footer-socials{display:flex;gap:8px}
.soc-btn{width:34px;height:34px;background:rgba(255,255,255,.05);border-radius:var(--rad);display:flex;align-items:center;justify-content:center;font-size:.78rem;color:rgba(255,255,255,.4);transition:var(--tr)}.soc-btn:hover{background:var(--violet);color:#fff}
.footer-col-title{font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:14px}.footer-links{display:flex;flex-direction:column;gap:9px}.footer-links a{font-size:.83rem;color:rgba(255,255,255,.45);transition:var(--tr)}.footer-links a:hover{color:var(--violet2)}
.footer-ci{display:flex;gap:9px;font-size:.81rem;margin-bottom:9px;align-items:flex-start}
.footer-bottom{padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.72rem}
.footer-legal{display:flex;gap:16px}.footer-legal a{color:rgba(255,255,255,.25)}.footer-legal a:hover{color:var(--violet2)}
#back-top{position:fixed;bottom:28px;right:28px;width:42px;height:42px;background:linear-gradient(135deg,var(--violet),var(--violet2));border:none;border-radius:var(--rad-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(12px);transition:var(--tr);z-index:900;color:#fff;font-size:1rem}
#back-top.show{opacity:1;transform:translateY(0)}#back-top:hover{transform:translateY(-3px)}
.reveal,.reveal-l,.reveal-r{opacity:0;transition:opacity .6s ease,transform .6s ease}
.reveal{transform:translateY(30px)}.reveal-l{transform:translateX(-30px)}.reveal-r{transform:translateX(30px)}
.reveal.revealed,.reveal-l.revealed,.reveal-r.revealed{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}.value-item{background:#fff;border:1px solid var(--border);border-radius:var(--rad);padding:16px 18px;border-top:3px solid var(--violet)}.value-item h4{font-size:.9rem;margin-bottom:5px;color:var(--text)}.value-item p{font-size:.78rem;color:var(--text-dim);margin:0}
.faq-item{padding:20px 0;border-bottom:1px solid rgba(0,0,0,.07)}.faq-item h3{font-size:.98rem;margin-bottom:8px;color:var(--text)}.faq-item p{font-size:.86rem;color:var(--text-dim);line-height:1.8;margin:0}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.text-center{text-align:center}
@media(max-width:1024px){.hero-content,.about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}.hero-content{text-align:center}.hero-sub{margin:0 auto 32px}.hero-ctas{justify-content:center}.hero-nums{justify-content:center}.services-grid,.t-grid,.team-grid{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr 1fr}.svc-full-card{grid-template-columns:1fr;gap:28px}.svc-full-card.flip{direction:ltr}.portfolio-grid{grid-template-columns:1fr}}
@media(max-width:768px){:root{--hh:62px}.main-nav,.nav-cta{display:none}.nav-toggle{display:flex}.section-pad{padding:68px 0}.services-grid,.t-grid,.team-grid,.footer-grid{grid-template-columns:1fr}.form-row,.values-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}.form-wrap{padding:26px 20px}}
@media(max-width:480px){.container{padding:0 16px}.hero-ctas,.cta-btns{flex-direction:column;align-items:center}.hero-ctas .btn,.cta-btns .btn{width:100%;justify-content:center}.hero-nums{flex-wrap:wrap;gap:18px}}
