/*
Theme Name: CareSurround
Theme URI: https://caresurround.co.uk
Author: CENSIS Technology Solutions Ltd
Author URI: https://censis.tech
Description: Marketing website for CareSurround — connected digital support for people, homes and services. Built by CENSIS Technology Solutions Ltd.
Version: 1.1.3
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: caresurround
Tags: one-page, business, video-hero, custom-logo, custom-menu
*/

:root{
  /* Navy palette — mirrors CENSIS for shared DNA */
  --navy-deep:#06102E;
  --navy:#0B1437;
  --navy-2:#0F1C4A;
  --navy-3:#15265E;
  --navy-4:#1D3070;
  --navy-5:#243B85;

  /* Teal accents — slightly brighter than CENSIS for CareSurround energy */
  --teal:#00B0D3;
  --teal-bright:#22D4ED;
  --teal-deep:#0093B0;
  --teal-glow:#3CE6FF;

  /* Light card surface */
  --card-light:#F6F8FB;
  --card-line:#E0E6F0;
  --card-line-strong:#C4CEDE;

  /* Text on dark */
  --text:#F4F7FB;
  --text-soft:#C9D3E2;
  --text-mute:#8993AD;
  --text-dim:#5E6A87;

  /* Text on light cards */
  --ink:#0B1437;
  --muted:#3A4258;
  --muted-soft:#5A6378;

  /* Shadows for dark theme */
  --shadow-md:0 14px 36px rgba(0,0,0,.35);
  --shadow-lg:0 26px 62px rgba(0,0,0,.45);
  --shadow-glow:0 0 60px rgba(34,212,237,.18);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* Navy gradient backdrop — shares DNA with CENSIS but with a slightly
   bluer cast and very faint teal-shifted waves for CareSurround energy. */
body{
  margin:0;
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--text);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  background:linear-gradient(180deg,
    var(--navy-deep) 0%,
    var(--navy) 12%,
    var(--navy-2) 26%,
    var(--navy-3) 42%,
    var(--navy-2) 58%,
    var(--navy) 76%,
    var(--navy-deep) 94%,
    var(--navy-deep) 100%
  );
}

/* Typography */
h1,h2,h3,h4{font-family:'Bricolage Grotesque','Manrope',sans-serif;font-weight:500;letter-spacing:-.025em;color:var(--text);margin:0;line-height:1.05;font-variation-settings:"opsz" 96}
h1{font-size:clamp(2.8rem,6vw,5rem);font-weight:400;letter-spacing:-.03em}
h2{font-size:clamp(2.1rem,4.2vw,3.4rem);font-weight:500;line-height:1.08;letter-spacing:-.028em;color:var(--text)}
h3{font-size:1.3125rem;font-weight:600;letter-spacing:-.012em;line-height:1.25;font-variation-settings:"opsz" 24;color:var(--text)}
p{margin:0;color:var(--text-soft);font-size:1.125rem;line-height:1.65}
h1 em, h2 em, h3 em { font-style: normal; color: var(--teal-bright); font-weight: 500; }
.hero-content h1 em { color: var(--teal-bright); font-weight: 500; }

.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
@media(max-width:640px){.wrap{padding:0 22px}}

/* HEADER — translucent dark with teal accent line */
header{position:sticky;top:0;z-index:50;background:rgba(11,20,55,.78);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(34,212,237,.14)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:18px 0}
.logo img{display:block;width:200px;height:auto;filter:brightness(0) invert(1)}
nav.links{display:flex;gap:4px;align-items:center;flex-wrap:wrap;justify-content:center}
nav.links a{font-size:.875rem;text-decoration:none;color:var(--text-soft);padding:9px 14px;border-radius:999px;font-weight:600;transition:all .2s ease;letter-spacing:.005em}
nav.links a:hover{background:rgba(34,212,237,.1);color:var(--teal-bright)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;padding:14px 24px;border-radius:999px;font-weight:600;font-size:.9375rem;transition:all .25s cubic-bezier(.2,.7,.3,1);white-space:nowrap;font-family:'Manrope',sans-serif;border:none;cursor:pointer;letter-spacing:.005em}
.btn-primary{background:white;color:var(--navy);box-shadow:0 8px 22px rgba(0,0,0,.3)}
.btn-primary:hover{background:#F4F7FB;transform:translateY(-1px);box-shadow:0 14px 32px rgba(0,0,0,.4)}
.btn-teal{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-bright) 100%);color:white;box-shadow:0 8px 22px rgba(0,176,211,.4),0 0 0 1px rgba(60,230,255,.2)}
.btn-teal:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(0,176,211,.55),0 0 30px rgba(60,230,255,.4)}
.btn-ghost-light{background:rgba(255,255,255,.08);color:white;border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(10px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.4)}
.btn .arrow{transition:transform .25s cubic-bezier(.2,.7,.3,1)}
.btn:hover .arrow{transform:translateX(4px)}

/* HERO VIDEO */
.hero-video{position:relative;width:100%;height:88vh;min-height:560px;max-height:820px;overflow:hidden;background:var(--navy)}
.hero-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-video::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,20,55,.4) 0%,rgba(11,20,55,.55) 50%,rgba(6,16,46,.92) 100%);z-index:2}
.hero-video::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 40%,rgba(34,212,237,.22),transparent 60%);z-index:2;mix-blend-mode:screen}
.hero-overlay{position:relative;z-index:3;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:88px}
.hero-content{max-width:980px;animation:fadeUp 1.1s cubic-bezier(.2,.7,.3,1) both}
.hero-content h1{color:white;font-weight:300;font-size:clamp(2.2rem,5.5vw,4.6rem);line-height:1.05;letter-spacing:-.03em;text-shadow:0 4px 40px rgba(0,0,0,.4)}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;animation:fadeUp 1.3s cubic-bezier(.2,.7,.3,1) .2s both}
.scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:4;color:rgba(255,255,255,.7);font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:14px;animation:fadeIn 1.5s 1s both}
.scroll-hint::after{content:"";width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* TRUST BAR — subtle translucent navy panel that reads slightly lifted
   from the body gradient, with hair-thin borders for clean bar edges. */
.trust-bar{
  background:rgba(15,28,74,.55);
  padding:28px 0;
  position:relative;
  border-top:1px solid rgba(255,255,255,.045);
  border-bottom:1px solid rgba(255,255,255,.045);
  backdrop-filter:blur(8px);
}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:center}
.trust-item{display:flex;align-items:center;gap:12px;color:var(--text);font-weight:600;font-size:.875rem;letter-spacing:.01em}
.trust-item svg{flex-shrink:0;width:22px;height:22px;color:var(--teal-bright)}
@media(max-width:880px){.trust-row{grid-template-columns:repeat(2,1fr);gap:18px}}

/* SECTIONS — transparent on body gradient with positional radial glows */
section{padding:30px 0;position:relative;overflow:hidden;background:transparent}
@media(max-width:760px){section{padding:30px 0}}
.section-intro{max-width:740px;margin-bottom:64px;position:relative;z-index:3}
.section-intro p{font-size:1.1875rem;color:var(--text-soft);margin-top:22px;max-width:680px}

/* Eyebrow pill — dark variant for dark page */
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--teal-bright);font-size:.6875rem;text-transform:uppercase;letter-spacing:.22em;font-weight:700;margin-bottom:24px;background:rgba(34,212,237,.08);padding:8px 16px;border-radius:999px;border:1px solid rgba(34,212,237,.2)}
.eyebrow::before{content:"";width:6px;height:6px;background:var(--teal-bright);border-radius:50%;box-shadow:0 0 12px var(--teal-bright)}

/* Positioning block */
.positioning{padding:60px 0}
.positioning-block{max-width:920px;position:relative;z-index:3}
.positioning-block .eyebrow{margin-bottom:30px}
.positioning-block .statement{font-family:'Bricolage Grotesque',sans-serif;font-weight:400;font-size:clamp(1.35rem,2.3vw,1.75rem);line-height:1.45;color:var(--text);letter-spacing:-.018em;font-variation-settings:"opsz" 32;margin:0}
.positioning-block .statement em{font-style:normal;color:var(--teal-bright);font-weight:500}
@media(max-width:760px){.positioning{padding:40px 0}}

/* Positional radial accents — teal glows on the dark backdrop */
.accent-tl::before{content:"";position:absolute;top:5%;left:-8%;width:45%;height:55%;background:radial-gradient(circle,rgba(34,212,237,.13),transparent 55%);pointer-events:none;z-index:0}
.accent-tr::before{content:"";position:absolute;top:5%;right:-8%;width:50%;height:60%;background:radial-gradient(circle,rgba(34,212,237,.14),transparent 55%);pointer-events:none;z-index:0}
.accent-bl::after{content:"";position:absolute;bottom:5%;left:-10%;width:45%;height:55%;background:radial-gradient(circle,rgba(0,176,211,.12),transparent 55%);pointer-events:none;z-index:0}
.accent-br::after{content:"";position:absolute;bottom:5%;right:-10%;width:50%;height:60%;background:radial-gradient(circle,rgba(34,212,237,.12),transparent 55%);pointer-events:none;z-index:0}

section .wrap{position:relative;z-index:3}

/* Subtle flow-curve decoration — sized to fill its section, with the visible
   curves landing in the section's middle by default. The "What it does"
   section has a diagram in the middle, so we shift the wave upward there
   via a transform, so the curves land above the diagram instead. */
.flow-curves{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;opacity:.4}
#what .flow-curves{height:min(100%, 900px);transform:translateY(-32%)}

/* INTRO + DIAGRAM */
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
@media(max-width:960px){.intro-grid{grid-template-columns:1fr;gap:56px}}

/* Diagram */
.diagram{position:relative;aspect-ratio:1/1;max-width:520px;margin:0 auto;width:100%}
.diagram-bg{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(34,212,237,.18),transparent 70%);border-radius:50%}
.diagram-rings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.diagram-rings .ring{position:absolute;border-radius:50%;border:1px dashed rgba(34,212,237,.35);animation:rotate 60s linear infinite}
.diagram-rings .ring.r1{width:70%;height:70%}
.diagram-rings .ring.r2{width:90%;height:90%;animation-duration:90s;animation-direction:reverse;border-style:dotted;border-color:rgba(34,212,237,.4)}
@keyframes rotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.diagram-centre{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36%;aspect-ratio:1;border-radius:50%;background:linear-gradient(135deg,var(--teal) 0%,var(--teal-bright) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:white;box-shadow:0 30px 60px rgba(0,0,0,.4),0 0 0 8px rgba(34,212,237,.08),0 0 60px rgba(34,212,237,.4);z-index:5}
.diagram-centre .label-small{font-size:.625rem;text-transform:uppercase;letter-spacing:.3em;color:rgba(255,255,255,.9);font-weight:700;margin-bottom:6px}
.diagram-centre .label-main{font-family:'Bricolage Grotesque',serif;font-size:1.0625rem;font-weight:500;line-height:1.15;padding:0 12px;color:white}
.node{position:absolute;width:150px;min-height:130px;background:var(--card-light);border-radius:18px;padding:14px 12px;text-align:center;font-weight:600;color:var(--ink);box-shadow:0 14px 30px rgba(0,0,0,.3);z-index:4;font-size:.8125rem;transition:transform .3s cubic-bezier(.2,.7,.3,1);border:1px solid rgba(255,255,255,.08)}
.node:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.45),0 0 30px rgba(34,212,237,.2)}
.node .node-icon{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,rgba(0,176,211,.18) 0%,rgba(34,212,237,.18) 100%);color:var(--teal-deep);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.node small{display:block;margin-top:4px;font-weight:500;color:var(--muted-soft);font-size:.75rem;line-height:1.35}
.n1{top:0;left:50%;transform:translateX(-50%)}
.n1:hover{transform:translateX(-50%) translateY(-4px)}
.n2{top:50%;right:0;transform:translateY(-50%)}
.n2:hover{transform:translateY(-50%) translateY(-4px)}
.n3{bottom:0;left:50%;transform:translateX(-50%)}
.n3:hover{transform:translateX(-50%) translateY(-4px)}
.n4{top:50%;left:0;transform:translateY(-50%)}
.n4:hover{transform:translateY(-50%) translateY(-4px)}

/* Section intro paragraph text on dark theme — diagram section is dense */
.intro-grid > div p { color: var(--text-soft); }

/* CARDS — light cards on dark navy */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:2}
.cards.two{grid-template-columns:repeat(2,1fr)}
.cards.four{grid-template-columns:repeat(4,1fr);gap:20px}
/* v1.1.2: 5-card variant uses flex-wrap so a 5th card sits centered on row 2
   rather than left-aligned and lonely. Cards keep their 4-up width at desktop. */
.cards.five{display:flex;flex-wrap:wrap;justify-content:center;gap:20px}
.cards.five > *{flex:0 1 calc(25% - 15px);max-width:280px;min-width:240px}
@media(max-width:960px){.cards,.cards.two,.cards.four{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:960px){.cards.five > *{flex:0 1 calc(50% - 10px);max-width:none}}
@media(max-width:640px){.cards,.cards.two,.cards.four{grid-template-columns:1fr}}
@media(max-width:640px){.cards.five > *{flex:0 1 100%}}

.card{background:var(--card-light);border:1px solid rgba(34,212,237,.08);border-radius:24px;padding:34px 30px;transition:all .35s cubic-bezier(.2,.7,.3,1);position:relative;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.2)}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));opacity:0;transition:opacity .35s}
.card:hover{transform:translateY(-6px);border-color:rgba(34,212,237,.4);box-shadow:0 20px 50px rgba(0,0,0,.35),0 0 40px rgba(34,212,237,.2)}
.card:hover::before{opacity:1}
.card h3{margin-bottom:12px;color:var(--ink)}
.card p{font-size:1rem;line-height:1.6;color:var(--muted)}
.icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(0,176,211,.15) 0%,rgba(34,212,237,.15) 100%);display:flex;align-items:center;justify-content:center;color:var(--teal-deep);margin-bottom:22px;transition:all .35s cubic-bezier(.2,.7,.3,1)}
.card:hover .icon{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-bright) 100%);color:white;transform:scale(1.05) rotate(-3deg);box-shadow:0 8px 24px rgba(34,212,237,.4)}
.icon svg{width:24px;height:24px}

/* DARK panel — used for the health vertical, slightly different to body */
.dark{background:linear-gradient(135deg,var(--navy-2) 0%,var(--navy-4) 100%);color:white;border-radius:28px;padding:56px 48px;position:relative;overflow:hidden;border:1px solid rgba(34,212,237,.15)}
.dark::before{content:"";position:absolute;top:-40%;right:-20%;width:60%;height:160%;background:radial-gradient(circle,rgba(34,212,237,.28),transparent 60%);pointer-events:none}
.dark::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:24px 24px;pointer-events:none;opacity:.5}
.dark h2,.dark h3{color:white;position:relative;z-index:2}
.dark p{color:rgba(255,255,255,.82);position:relative;z-index:2;font-size:1.0625rem}

/* PLATFORM cards */
.platform-card{background:var(--card-light);border:1px solid rgba(34,212,237,.08);border-radius:20px;padding:28px 22px;text-align:left;transition:all .35s cubic-bezier(.2,.7,.3,1);position:relative;box-shadow:0 6px 20px rgba(0,0,0,.2)}
.platform-card:hover{transform:translateY(-4px);border-color:rgba(34,212,237,.4);box-shadow:0 16px 40px rgba(0,0,0,.3),0 0 30px rgba(34,212,237,.15)}
.platform-card .num-badge{position:absolute;top:18px;right:20px;font-family:'Bricolage Grotesque',sans-serif;font-size:1.5rem;font-weight:500;color:var(--card-line-strong);transition:color .3s;font-variation-settings:"opsz" 96}
.platform-card:hover .num-badge{color:var(--teal)}
.platform-card h3{font-size:1.125rem;margin-top:18px;margin-bottom:8px;color:var(--ink)}
.platform-card p{font-size:.9375rem;line-height:1.55;color:var(--muted)}
.platform-card .icon{width:44px;height:44px;border-radius:12px;margin-bottom:0}
.platform-card .icon svg{width:20px;height:20px}

/* USE CASE cards */
.use-card{background:var(--card-light);border:1px solid rgba(34,212,237,.08);border-radius:22px;padding:32px 28px;transition:all .35s cubic-bezier(.2,.7,.3,1);position:relative;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.2)}
.use-card .bar{width:48px;height:4px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));border-radius:999px;margin-bottom:22px;transition:width .35s cubic-bezier(.2,.7,.3,1);box-shadow:0 0 12px rgba(34,212,237,.4)}
.use-card:hover{transform:translateY(-4px);border-color:rgba(34,212,237,.4);box-shadow:0 16px 40px rgba(0,0,0,.3),0 0 30px rgba(34,212,237,.15)}
.use-card:hover .bar{width:80px}
.use-card h3{margin-bottom:10px;color:var(--ink)}
.use-card p{font-size:1rem;line-height:1.6;color:var(--muted)}

/* HEALTH steps */
.health-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:stretch}
@media(max-width:960px){.health-grid{grid-template-columns:1fr;gap:32px}}
.stepgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.step{background:var(--card-light);border:1px solid rgba(34,212,237,.08);border-radius:20px;padding:26px 22px;position:relative;transition:all .35s cubic-bezier(.2,.7,.3,1);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.step:hover{border-color:rgba(34,212,237,.4);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.3),0 0 30px rgba(34,212,237,.15)}
.step:hover .num{background:var(--teal);color:white;box-shadow:0 0 20px rgba(34,212,237,.5)}
.num{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,176,211,.15) 0%,rgba(34,212,237,.15) 100%);color:var(--teal-deep);font-weight:600;margin-bottom:14px;transition:all .3s;font-family:'Bricolage Grotesque',sans-serif;font-size:1.125rem;font-variation-settings:"opsz" 24}
.step h3{font-size:1.0625rem;margin-bottom:6px;color:var(--ink)}
.step p{font-size:.9375rem;line-height:1.55;color:var(--muted)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch}
@media(max-width:960px){.contact-grid{grid-template-columns:1fr}}
.contact-info{background:linear-gradient(135deg,var(--navy-2) 0%,var(--navy-4) 100%);color:white;border-radius:28px;padding:48px 42px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;border:1px solid rgba(34,212,237,.15)}
.contact-info::before{content:"";position:absolute;top:-30%;right:-25%;width:60%;height:150%;background:radial-gradient(circle,rgba(34,212,237,.28),transparent 60%);pointer-events:none}
.contact-info::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:24px 24px;pointer-events:none;opacity:.5}
.contact-info > *{position:relative;z-index:2}
.contact-info h2{color:white;margin-bottom:14px}
.contact-info h2 em{color:var(--teal-bright);font-weight:500}
.contact-info p{color:rgba(255,255,255,.82);font-size:1rem;line-height:1.65}
.contact-info .addr{margin-top:32px;padding-top:32px;border-top:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.86);font-size:.9375rem;line-height:1.7}
.contact-info .addr strong{color:white;display:block;font-weight:600;margin-bottom:6px;letter-spacing:.005em}

.form-card{background:var(--card-light);border:1px solid rgba(34,212,237,.08);border-radius:28px;padding:42px 36px;box-shadow:var(--shadow-md);color:#0B1437}
.form-card .form-title,.form-card h3.form-title,.form-card .wpcf7 .form-title,.form-card form .form-title{font-family:'Bricolage Grotesque',sans-serif;font-size:1.5rem;font-weight:500;color:#0B1437!important;margin:0 0 6px 0!important;letter-spacing:-.02em;font-variation-settings:"opsz" 32}
.form-card .form-sub,.form-card p.form-sub,.form-card .wpcf7 .form-sub,.form-card form .form-sub{font-size:.9375rem;color:#525B72!important;margin:0 0 28px 0!important;line-height:1.55}
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label,.form-card .wpcf7 label,.form-card form label{font-size:.75rem;font-weight:600;color:#0B1437!important;text-transform:uppercase;letter-spacing:.12em;display:block;margin-bottom:8px}
.form .field{display:flex;flex-direction:column}
.form .field.full{grid-column:1/-1}
.form input,.form select,.form textarea{width:100%;border:1.5px solid var(--card-line);border-radius:14px;padding:14px 16px;font:inherit;color:var(--ink);background:white;transition:all .2s ease;font-size:.9375rem}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--teal);background:white;box-shadow:0 0 0 4px rgba(0,176,211,.12)}
.form textarea{min-height:130px;resize:vertical;font-family:inherit}
@media(max-width:640px){.form{grid-template-columns:1fr}}

/* Contact Form 7 integration — normalise CF7 markup so the form looks native.
   CF7 wraps inputs in <span class="wpcf7-form-control-wrap"> and emits <br>
   elements. These rules make the grid layout hold. Lessons learned from the
   sister CENSIS theme: use !important and literal hex on critical colours,
   keep specificity high. */
.form-card .wpcf7 { margin: 0; padding: 0; }
.form-card .wpcf7 form { margin: 0; padding: 0; }
.form-card .wpcf7 br { display: none; }
.form-card .wpcf7 .wpcf7-form-control-wrap { display: block; width: 100%; }
.form-card .wpcf7 .wpcf7-form-control-wrap input,
.form-card .wpcf7 .wpcf7-form-control-wrap select,
.form-card .wpcf7 .wpcf7-form-control-wrap textarea { width: 100%; }
/* Validation messages */
.form-card .wpcf7 .wpcf7-not-valid-tip { font-size: .8125rem; color: #C2410C; margin-top: 6px; font-weight: 600; }
.form-card .wpcf7-response-output { border: none !important; margin: 18px 0 0 !important; padding: 14px 16px !important; border-radius: 12px; font-size: .9375rem; }
.form-card .wpcf7 form.sent .wpcf7-response-output { background: rgba(0,176,211,.12); color: #0093B0; }
.form-card .wpcf7 form.invalid .wpcf7-response-output,
.form-card .wpcf7 form.failed .wpcf7-response-output,
.form-card .wpcf7 form.spam .wpcf7-response-output { background: rgba(194,65,12,.1); color: #C2410C; }
/* CF7 emits a <p> wrapper around [submit] */
.form-card .wpcf7 p:has(.wpcf7-submit) { margin: 22px 0 0; }
.form-card .wpcf7-submit.btn { width: 100%; justify-content: center; cursor: pointer; }
.form-card .wpcf7-spinner { vertical-align: middle; }

/* FOOTER — navy gradient continuing from body */
footer{background:linear-gradient(180deg,var(--navy-deep) 0%,#040918 100%);color:white;padding:80px 0 40px;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;top:0;right:-10%;width:50%;height:100%;background:radial-gradient(circle at top right,rgba(34,212,237,.18),transparent 60%);pointer-events:none}
footer::after{content:"";position:absolute;bottom:-50%;left:-15%;width:40%;height:120%;background:radial-gradient(circle,rgba(34,212,237,.1),transparent 60%);pointer-events:none}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;position:relative;z-index:2}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr;gap:32px}}
footer .logo img{width:200px;filter:brightness(0) invert(1);opacity:.95}
footer .footer-tag{color:rgba(255,255,255,.66);font-size:.9375rem;line-height:1.65;margin-top:20px;max-width:340px}
footer h4{color:white;font-family:'Manrope',sans-serif;font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;font-weight:700;margin:0 0 18px}
footer .links-col{display:flex;flex-direction:column;gap:11px}
footer .links-col a{color:rgba(255,255,255,.7);text-decoration:none;font-size:.9375rem;transition:color .2s}
footer .links-col a:hover{color:var(--teal-bright)}
footer .contact-detail{color:rgba(255,255,255,.7);font-size:.9375rem;line-height:1.7;font-style:normal}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;position:relative;z-index:2}
.footer-bottom p{color:rgba(255,255,255,.5);font-size:.8125rem;margin:0}
.footer-bottom .legal{display:flex;gap:24px}
.footer-bottom .legal a{color:rgba(255,255,255,.6);font-size:.8125rem;text-decoration:none}
.footer-bottom .legal a:hover{color:white}

/* Reveals */
.reveal{opacity:0;transform:translateY(28px);transition:all .9s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:all .7s cubic-bezier(.2,.7,.3,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.08s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.24s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.32s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}

@media(max-width:880px){
  nav.links{display:none}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{justify-content:center}
  .hero-overlay{padding-bottom:60px}
  .dark,.contact-info,.form-card{padding:36px 26px}
  .stepgrid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav .btn-primary{display:none}
  .logo img{width:170px}
}

/* ==========================================================================
   v1.1.0 — Gutenberg block-editor integration
   The homepage can now be composed in the block editor from CareSurround
   patterns. WordPress wraps Group blocks in <div class="wp-block-group ...">
   and applies an automatic vertical "block gap" between siblings of flow
   layouts. These rules neutralise those auto-margins inside our custom
   containers so our hand-tuned spacing wins, and they make sure pattern
   markup renders pixel-identically to the original hardcoded sections.
   ========================================================================== */

/* Group blocks render as the section/div container.

   NOTE: We deliberately do NOT add a blanket `.wp-block-group{max-width:none}`
   rule here, because that would override the `.wrap{max-width:1200px}` rule
   for any pattern element that also carries the `wp-block-group` class. */
.wp-block-heading{margin-top:0;margin-bottom:0}

/* Reset Gutenberg's "* + *" block-gap on the inside of our custom
   structural containers. We provide all vertical spacing explicitly via
   class-based margins. */
.wp-block-group.hero-content > * + *,
.wp-block-group.section-intro > * + *,
.wp-block-group.intro-text > * + *,
.wp-block-group.positioning-block > * + *,
.wp-block-group.dark > * + *,
.wp-block-group.contact-info > * + *,
.wp-block-group.contact-info > div > * + *,
.wp-block-group.card > * + *,
.wp-block-group.use-card > * + *,
.wp-block-group.platform-card > * + *,
.wp-block-group.step > * + *,
.wp-block-group.form-card > * + *,
.wp-block-group.health-grid > * + *,
.wp-block-group.contact-grid > * + *{margin-block-start:0;margin-top:0}

/* v1.1.1 fix: zero block-gap on direct children of CSS-grid containers.
   Without this, WordPress's automatic 24px margin-block-start on siblings
   pushes cards 2+ down within their grid cells, making card 1 appear taller. */
.wp-block-group.cards > *,
.wp-block-group.cards.two > *,
.wp-block-group.cards.four > *,
.wp-block-group.cards.five > *,
.wp-block-group.cards.what-cards > *,
.wp-block-group.stepgrid > *,
.wp-block-group.intro-grid > *,
.wp-block-group.health-grid > *,
.wp-block-group.contact-grid > *{margin-block-start:0;margin-top:0}

/* Re-apply the deliberate margins our design relies on inside section-intro
   (where the heading sits below the eyebrow and the paragraph sits below
   the heading). These match the original hardcoded spacing. */
.wp-block-group.section-intro > .wp-block-heading{margin-top:0}
.wp-block-group.section-intro > p{margin-top:22px}
.wp-block-group.intro-text > .wp-block-heading{margin-top:0}
.wp-block-group.intro-text > p{margin-top:24px}
.wp-block-group.intro-text > .intro-actions{margin-top:32px}
.intro-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Hero heading + buttons spacing inside the editor-composed hero */
.wp-block-group.hero-content > .wp-block-heading{margin-top:0}
.wp-block-group.hero-content > .hero-actions{margin-top:36px}

/* Dark callout panel: heading then paragraph */
.wp-block-group.dark > .wp-block-heading{margin-top:0}
.wp-block-group.dark > p{margin-top:18px}

/* Cards: icon (HTML block) → heading → paragraph spacing */
.wp-block-group.card > .wp-block-heading{margin-top:0;margin-bottom:12px}
.wp-block-group.card > p{margin-top:0}
.wp-block-group.platform-card > .wp-block-heading{margin-top:18px;margin-bottom:8px}
.wp-block-group.platform-card > p{margin-top:0}
.wp-block-group.use-card > .wp-block-heading{margin-top:0;margin-bottom:10px}
.wp-block-group.use-card > p{margin-top:0}
.wp-block-group.step > .wp-block-heading{margin-top:0;margin-bottom:6px}
.wp-block-group.step > p{margin-top:0}

/* Positioning statement: no top margin even though it's after the eyebrow
   HTML block (the eyebrow's margin-bottom: 30px from .positioning-block
   .eyebrow provides the gap). */
.wp-block-group.positioning-block > .statement,
.wp-block-group.positioning-block > p.statement{margin-top:0}

/* Cards row sitting after the intro-grid in the "What it does" pattern */
.wp-block-group.cards.what-cards{margin-top:96px}

/* Callout heading variant ("is-style-callout"): smaller than a normal h2,
   used inside dark and contact-info panels. */
.is-style-callout{font-size:clamp(1.6rem,3vw,2.4rem)}
.contact-info .is-style-callout{font-size:clamp(1.6rem,2.8vw,2.1rem)}

/* The callout-after-cards modifier just gives a top margin matching the
   old inline style in section-who. */
.callout-after-cards{margin-top:48px}

/* Make sure the form-card's children don't pick up Gutenberg margins */
.wp-block-group.form-card > p,
.wp-block-group.form-card > h3{margin-top:0}

/* ==========================================================================
   v1.1.0 — Accessibility
   Skip-to-content link, visible focus styles on all interactive elements,
   and a prefers-reduced-motion override that disables non-essential
   animations for users who've requested reduced motion.
   ========================================================================== */

/* Skip link — visually hidden until focused via Tab */
.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
  z-index:100;
}
.skip-link:focus{
  position:fixed;
  top:12px;
  left:12px;
  width:auto;
  height:auto;
  padding:12px 20px;
  background:var(--teal);
  color:white;
  font-weight:600;
  border-radius:8px;
  text-decoration:none;
  box-shadow:0 8px 22px rgba(0,0,0,.4);
  outline:3px solid white;
  outline-offset:2px;
}

/* Visible focus rings for keyboard users on all interactive elements.
   Uses :focus-visible so mouse clicks don't show the ring. */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.btn:focus-visible,
nav.links a:focus-visible{
  outline:3px solid var(--teal-bright);
  outline-offset:3px;
  border-radius:6px;
}

/* Buttons already use rounded shapes — match the focus ring radius so it
   hugs the button rather than showing as a square. */
.btn:focus-visible{
  outline-offset:4px;
  border-radius:999px;
}

/* Navigation links use pill shape on hover — match for focus */
nav.links a:focus-visible{
  border-radius:999px;
}

/* Card hover targets are large but the cards aren't focusable themselves
   (no anchor wrapping them). If a card contains a link, that link gets
   focused — make sure the visible ring isn't clipped by overflow. */
.card,.use-card,.platform-card,.step{position:relative}

/* Reduced motion: respect user's system preference. Disables decorative
   animations (ring rotation, scroll-line, reveals) but keeps focus rings,
   transitions necessary for usability. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal,.reveal-stagger > *{opacity:1 !important;transform:none !important}
  .diagram-rings .ring{animation:none !important}
  .scroll-hint::after{animation:none !important}
  .hero-content,.hero-actions{animation:none !important}
}

/* ==========================================================================
   v1.1.0 — Mobile responsiveness tightening
   The site already had breakpoints at 960, 880, 760, 640, 540px. These
   additions improve tap-target sizes (44x44px minimum per WCAG 2.5.5),
   reduce hero height on small screens, and stack the diagram below the
   intro text at narrow widths so it doesn't get squashed.
   ========================================================================== */

/* Hero adjustments at very narrow widths */
@media(max-width:640px){
  .hero-video{height:auto;min-height:520px;padding:140px 0 60px}
  .hero-overlay{padding-bottom:40px}
  .hero-content h1{font-size:clamp(1.9rem,8vw,2.6rem)}
  .scroll-hint{display:none}
}

/* Diagram: at narrow widths, give it more breathing room and ensure node
   labels don't overlap. Below 520px the nodes become quite tight; we
   shrink them slightly so the diagram still reads cleanly. */
@media(max-width:520px){
  .diagram{max-width:340px}
  .node{width:108px;font-size:.75rem;padding:10px 8px}
  .node small{font-size:.6875rem;margin-top:2px}
  .node .node-icon{width:26px;height:26px;margin-bottom:4px}
  .diagram-centre .label-main{font-size:.9375rem}
}

/* Minimum tap-target size (WCAG 2.5.5 — 44x44px) on all clickable links */
nav.links a,
.footer-bottom .legal a,
footer .links-col a{min-height:44px;display:inline-flex;align-items:center}

/* Buttons already meet the size requirement, but ensure the smaller
   gap-buttons inside hero-actions have enough vertical space */
.btn{min-height:44px}

/* Mobile menu fallback: when the primary nav is hidden at <880px, surface
   the contact button (currently hidden at <640px). Below 480px the logo
   stays prominent and there's no clutter. */
@media(max-width:880px){
  .hero-actions{gap:12px}
  .hero-actions .btn{padding:14px 20px;font-size:.875rem}
}

/* Form inputs already meet WCAG, but ensure labels don't get cramped */
@media(max-width:480px){
  .form-card{padding:30px 22px}
  .form input,.form select,.form textarea{font-size:1rem} /* ≥16px prevents iOS zoom */
}

/* Footer reflow at very narrow widths */
@media(max-width:380px){
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:14px}
  .footer-bottom .legal{flex-wrap:wrap;gap:12px 18px}
}

/* Reduce excessive horizontal padding on the smallest devices */
@media(max-width:380px){
  .wrap{padding:0 18px}
  .card,.use-card,.platform-card,.step{padding:28px 22px}
}
