/*
Theme Name: CJS Support
Theme URI: https://www.cjssupport.co.uk
Author: CJS Support
Description: A bright, modern WordPress theme for CJS Support, independent criminal justice support and solicitor signposting.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
Text Domain: cjs-support
*/

:root{
  --blue:#1E73D8;
  --navy:#072B57;
  --green:#69C33D;
  --orange:#F5A623;
  --light:#F7FAFC;
  --soft-blue:#EAF4FF;
  --muted:#526579;
  --white:#ffffff;
  --shadow:0 14px 35px rgba(7,43,87,.11);
  --radius:22px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:#10243f;
  background:#fff;
  line-height:1.6;
}
img{max-width:100%;height:auto}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1180px,92vw);margin:0 auto}
.small-caps{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#55951f;font-weight:800}
h1,h2,h3,h4{font-family:Poppins, Inter, sans-serif;color:var(--navy);line-height:1.08;margin:0 0 18px}
h1{font-size:clamp(2.4rem,5vw,5rem);letter-spacing:-.055em}
h2{font-size:clamp(2rem,3.5vw,3.4rem);letter-spacing:-.04em;text-align:center}
h3{font-size:1.35rem}
p{margin:0 0 18px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.65rem;
  padding:14px 24px;border-radius:12px;font-weight:800;border:2px solid var(--blue);
  text-decoration:none;transition:.2s ease;cursor:pointer
}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 20px rgba(30,115,216,.25)}
.btn-outline{background:#fff;color:var(--blue)}
.btn-green{background:var(--green);border-color:var(--green);color:#fff}
.badge-row{display:flex;flex-wrap:wrap;gap:18px;margin-top:24px}
.badge{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:#183956;font-size:.94rem}
.badge span{width:26px;height:26px;border-radius:50%;display:inline-grid;place-items:center;background:#eef8e8;color:#4d9b21}

.topbar{background:var(--navy);color:#fff;font-size:.9rem;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;gap:15px;flex-wrap:wrap}
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #e8eef5;box-shadow:0 6px 18px rgba(7,43,87,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:22px;min-height:86px}
.logo-wrap{display:flex;align-items:center;gap:12px}
.logo-wrap img{width:205px;display:block}
.site-nav{display:flex;align-items:center;gap:24px;font-weight:800;font-size:.95rem}
.site-nav a{color:#10243f;text-decoration:none}
.site-nav a:hover{color:var(--blue)}
.mobile-note{display:none}

.hero{
  position:relative;overflow:hidden;background:linear-gradient(100deg,#fff 0%,#fff 48%,#eaf7ff 100%);
  padding:62px 0 36px
}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:42px}
.hero-copy{position:relative;z-index:2}
.hero-copy h1 span{color:var(--green)}
.hero-copy p.lead{font-size:1.22rem;font-weight:700;color:#10243f;max-width:690px}
.hero-copy p{max-width:650px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin:26px 0}
.hero-visual{
  min-height:440px;border-radius:0 0 0 90px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#f8fbff 0%,#e8f6ff 55%,#d9f0ce 100%);
  box-shadow:var(--shadow)
}
.person-card{
  position:absolute;right:7%;top:10%;width:58%;height:56%;border-radius:28px;
  background:linear-gradient(150deg,#ffffff 0%,#dbe7f2 100%);
  box-shadow:0 24px 50px rgba(7,43,87,.16)
}
.person-card:before{content:"";position:absolute;left:16%;top:14%;width:72px;height:72px;border-radius:50%;background:#d6e0e9}
.person-card:after{content:"";position:absolute;left:10%;bottom:14%;width:72%;height:58px;border-radius:40px;background:#c8d6e4}
.path-scene{position:absolute;left:3%;bottom:-6%;width:105%;height:76%}
.sun{position:absolute;left:17%;top:18%;width:130px;height:130px;border-radius:50%;background:linear-gradient(#ffd35c,var(--orange))}
.ray{position:absolute;background:var(--orange);border-radius:10px;width:8px;height:40px;left:calc(17% + 62px);top:8%;transform-origin:50% 110px}
.ray.r2{transform:rotate(35deg)}
.ray.r3{transform:rotate(-35deg)}
.ray.r4{transform:rotate(70deg)}
.ray.r5{transform:rotate(-70deg)}
.path-blue,.path-green,.path-white{position:absolute;bottom:-20px;border-radius:60% 70% 0 0;transform:rotate(-10deg)}
.path-blue{left:7%;width:95%;height:170px;background:linear-gradient(100deg,var(--blue),#64b7ff)}
.path-green{left:34%;width:58%;height:160px;background:linear-gradient(100deg,#8de061,var(--green))}
.path-white{left:22%;width:44%;height:200px;background:#fff}

.cards-section{padding:54px 0;background:#fff}
.card-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:30px}
.info-card{
  background:#fff;border:1px solid #e8eef5;border-radius:18px;padding:26px 18px;text-align:center;
  box-shadow:var(--shadow);min-height:210px;transition:.2s ease
}
.info-card:hover{transform:translateY(-4px)}
.icon-circle{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;background:#eaf4ff;color:var(--blue);font-size:1.8rem}
.info-card:nth-child(2) .icon-circle{background:#eff9e9;color:#55951f}
.info-card:nth-child(3) .icon-circle{background:#f0eaff;color:#6246b9}
.info-card:nth-child(4) .icon-circle{background:#fff1df;color:#dc8500}
.info-card:nth-child(5) .icon-circle{background:#fff0f0;color:#db5151}
.info-card:nth-child(6) .icon-circle{background:#e7fbf6;color:#159b88}
.info-card p{font-size:.94rem;margin-bottom:0}

.process{background:linear-gradient(180deg,#f4faff,#ffffff);padding:58px 0;position:relative;overflow:hidden}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:36px;text-align:center}
.step-number{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:#dcecff;color:var(--blue);font-size:1.5rem;font-weight:900;margin:0 auto 18px}
.steps .step:nth-child(2) .step-number{background:#e4f5d9;color:#4e9e20}
.steps .step:nth-child(3) .step-number{background:#eee8ff;color:#5f45bd}
.center-note{text-align:center;margin-top:28px;color:#4c647b;font-weight:700}

.trust-strip{background:#fff;border-top:1px solid #e8eef5;border-bottom:1px solid #e8eef5;padding:25px 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.trust-item{display:flex;gap:14px;align-items:flex-start}
.trust-icon{font-size:2rem;color:var(--blue)}
.trust-item p{font-size:.95rem;margin:4px 0 0}

.split-section{padding:60px 0;background:#fff9ec}
.split-grid{display:grid;grid-template-columns:.95fr 1.05fr .75fr;gap:34px;align-items:center}
.path-photo{height:255px;border-radius:20px;background:linear-gradient(135deg,#ffe6a8,#dff1cc 45%,#7bb7ff);position:relative;overflow:hidden;box-shadow:var(--shadow)}
.path-photo:after{content:"";position:absolute;bottom:-40px;left:16%;width:36%;height:270px;background:#fff;border-radius:50%;transform:rotate(30deg)}
.list-check{list-style:none;padding:0;margin:0}
.list-check li{margin:9px 0;padding-left:30px;position:relative}
.list-check li:before{content:"✓";position:absolute;left:0;top:0;color:var(--green);font-weight:900}

.form-resources{padding:56px 0;background:#f6fbff}
.form-panel{
  display:grid;grid-template-columns:.85fr 1.4fr .65fr;gap:28px;align-items:center;
  background:#fff;border-radius:26px;padding:30px;box-shadow:var(--shadow)
}
.mini-logo{width:170px}
.callback-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.callback-form input,.callback-form select,.callback-form textarea{
  width:100%;border:1px solid #d6e2ee;border-radius:9px;padding:12px 14px;font-family:inherit;font-size:1rem;background:#fff
}
.callback-form textarea{grid-column:1/-1;min-height:90px}
.callback-form .full{grid-column:1/-1}
.secure{font-size:.88rem;color:#4c647b;margin-top:12px;text-align:center}

.footer{background:var(--navy);color:#e8f2ff;padding:44px 0 0}
.footer a{color:#e8f2ff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:30px}
.footer-logo{width:190px;margin-bottom:16px}
.footer h4{color:#fff;margin-bottom:12px}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin:7px 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.16);margin-top:36px;padding:18px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.9rem}

.page-hero{padding:62px 0;background:linear-gradient(135deg,#eef8ff,#fff)}
.page-hero h1{font-size:clamp(2.3rem,4vw,4.1rem)}
.page-content{padding:54px 0}
.content-card{background:#fff;border:1px solid #e8eef5;border-radius:22px;padding:34px;box-shadow:var(--shadow);margin-bottom:24px}
.content-card h2{text-align:left;font-size:2rem}
.cta-band{background:linear-gradient(135deg,var(--blue),#0b4fa8);color:#fff;border-radius:24px;padding:34px;margin:34px 0}
.cta-band h2,.cta-band h3{color:#fff;text-align:left}
.cta-band .btn{background:#fff;color:var(--blue);border-color:#fff}

@media(max-width:980px){
  .site-nav{display:none}.mobile-note{display:block;font-weight:800;color:var(--blue)}
  .hero-grid,.split-grid,.form-panel{grid-template-columns:1fr}
  .hero-visual{min-height:310px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .steps,.trust-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .logo-wrap img{width:170px}
}
@media(max-width:620px){
  .topbar{display:none}
  .header-inner{min-height:74px}
  .hero{padding-top:34px}
  .hero-actions .btn{width:100%}
  .badge-row{gap:10px}
  .card-grid,.steps,.trust-grid,.footer-grid{grid-template-columns:1fr}
  .callback-form{grid-template-columns:1fr}
  .split-section,.cards-section,.process,.form-resources{padding:38px 0}
  .form-panel{padding:22px}
}
