/* ================================================
   Unique Custom Exteriors — shared styles
   Brand color sampled from the existing logo (#501478)
   ================================================ */

:root{
  --purple:#501478;
  --purple-dark:#3a0e59;
  --purple-deep:#2a0844;
  --purple-50:#f6f1fb;
  --purple-100:#ece1f5;
  --purple-200:#d4bee8;
  --purple-300:#b794d7;
  --gold:#d4a24c;
  --ink:#1f1330;
  --muted:#5f5570;
  --cream:#fbf9f4;
  --surface:#ffffff;
  --line:rgba(31,19,48,.12);
  --shadow-sm:0 2px 8px rgba(31,19,48,.06);
  --shadow:0 14px 40px rgba(31,19,48,.14);
  --radius:14px;
  --radius-lg:22px;
  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

h1,h2,h3,h4,h5{
  font-family:"Fraunces",serif;
  font-weight:600;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .4em;
  line-height:1.12;
}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:500;letter-spacing:-.02em}
h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
h3{font-size:1.4rem}
h4{font-size:1.15rem}
p{margin:0 0 1em;color:var(--muted)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  font-weight:600;
  color:var(--purple);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:14px 26px;border-radius:999px;
  font-weight:600;font-size:.95rem;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  border:none;text-decoration:none;
}
.btn-primary{background:var(--purple);color:#fff;box-shadow:0 8px 24px rgba(80,20,120,.28)}
.btn-primary:hover{background:var(--purple-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-outline{background:#fff;color:var(--purple);border:1.5px solid var(--purple)}
.btn-outline:hover{background:var(--purple);color:#fff}
.btn svg{width:18px;height:18px}

/* ---------- Top bar + nav ---------- */
.topbar{
  background:var(--purple-deep);
  color:#e7d9f5;
  font-size:.85rem;
}
.topbar .wrap{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 24px;gap:12px;flex-wrap:wrap;
}
.topbar a{color:#e7d9f5;opacity:.9}
.topbar a:hover{opacity:1;color:#fff}
.topbar .jobs{display:inline-flex;align-items:center;gap:.5rem}
.topbar .jobs::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 0 rgba(212,162,76,.6);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(212,162,76,.6)}
  70%{box-shadow:0 0 0 10px rgba(212,162,76,0)}
  100%{box-shadow:0 0 0 0 rgba(212,162,76,0)}
}
.topbar-right{display:flex;align-items:center;gap:16px}
.lang{padding:2px 10px;border:1px solid rgba(255,255,255,.22);border-radius:999px}
.lang:hover{background:rgba(255,255,255,.1)}

header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;max-width:var(--maxw);margin:0 auto;
  gap:20px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:52px;width:auto}
nav.primary ul{display:flex;gap:28px;list-style:none;margin:0;padding:0}
nav.primary a{
  font-size:.95rem;font-weight:500;color:var(--ink);
  position:relative;padding:6px 0;
}
nav.primary a.is-current{color:var(--purple)}
nav.primary a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--purple);transition:width .25s ease;
}
nav.primary a:hover::after,
nav.primary a.is-current::after{width:100%}
.nav-cta{display:flex;gap:12px;align-items:center}
.nav-phone{font-weight:600;color:var(--purple)}
.nav-toggle{
  display:none;background:none;border:1px solid var(--line);
  padding:10px;border-radius:10px;
}
.nav-toggle svg{width:22px;height:22px;color:var(--ink)}
@media (max-width:980px){
  nav.primary ul, .nav-phone{display:none}
  .nav-toggle{display:inline-flex}
  nav.primary.is-open ul{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:#fff;border-bottom:1px solid var(--line);
    padding:18px 24px;gap:12px;
  }
}

/* ---------- Hero (home) ---------- */
.hero{
  position:relative;min-height:82vh;display:grid;align-items:center;
  color:#fff;overflow:hidden;isolation:isolate;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url("../assets/hero.jpg") center/cover no-repeat;transform:scale(1.04);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(1400px 700px at 20% 30%, rgba(80,20,120,.55), transparent 60%),
    linear-gradient(120deg, rgba(30,10,55,.9) 0%, rgba(30,10,55,.6) 55%, rgba(30,10,55,.25) 100%);
}
.hero .wrap{padding-top:80px;padding-bottom:80px}
.hero .eyebrow{color:#e2cff5}
.hero h1{color:#fff;max-width:16ch;margin-bottom:.2em}
.hero p.lede{font-size:1.2rem;max-width:58ch;color:rgba(255,255,255,.88);margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.hero-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  background:linear-gradient(to top, rgba(30,10,55,.75), transparent);
  padding:18px 0 24px;
}
.hero-meta-inner{
  display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;align-items:center;
  max-width:var(--maxw);margin:0 auto;padding:0 24px;color:#e2cff5;font-size:.9rem;
}
.hero-meta-inner strong{
  color:#fff;font-family:"Fraunces",serif;font-size:1.2rem;margin-right:6px;
}

/* ---------- Page hero (smaller) ---------- */
.page-hero{
  background:
    linear-gradient(180deg, rgba(30,10,55,.7), rgba(30,10,55,.82)),
    url("../assets/hero.jpg") center/cover no-repeat;
  color:#fff;padding:90px 0 70px;border-bottom:6px solid var(--purple);
}
.page-hero h1{color:#fff;max-width:20ch;font-size:clamp(2rem,4vw,3.2rem)}
.page-hero p{color:rgba(255,255,255,.85);max-width:60ch;font-size:1.1rem}
.page-hero .eyebrow{color:var(--purple-300)}
.crumbs{display:flex;gap:8px;color:rgba(255,255,255,.7);font-size:.85rem;margin-bottom:14px}
.crumbs a:hover{color:#fff}
.crumbs span{opacity:.5}

/* ---------- Section scaffolding ---------- */
section{padding:90px 0}
.section-head{max-width:720px;margin-bottom:48px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- Value props ---------- */
.values{background:var(--purple-50)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:10px}
.value-card{
  background:#fff;border-radius:var(--radius-lg);padding:34px 28px;
  border:1px solid var(--line);transition:transform .25s, box-shadow .25s;
}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.value-card .ico{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--purple-100),var(--purple-50));
  color:var(--purple);display:grid;place-items:center;margin-bottom:18px;
}
.value-card .ico svg{width:28px;height:28px}
.value-card h3{font-size:1.2rem;margin-bottom:8px}
.value-card p{margin:0;font-size:.95rem}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:70px;padding:36px;border-radius:var(--radius-lg);
  background:var(--purple-deep);color:#efe3ff;
}
.stat{padding:10px 20px;border-right:1px solid rgba(255,255,255,.12);text-align:center}
.stat:last-child{border-right:none}
.stat .num{
  font-family:"Fraunces",serif;font-size:2.6rem;color:#fff;
  line-height:1;display:block;margin-bottom:6px;font-weight:500;
}
.stat .num em{color:var(--gold);font-style:normal}
.stat .lbl{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;opacity:.8}
@media(max-width:900px){
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:20px 0}
  .stat{border-right:none}
  .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.12)}
}
@media(max-width:540px){
  .values-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.12);padding:18px}
  .stat:last-child{border-bottom:none}
}

/* ---------- Services ---------- */
.services{background:var(--cream)}
.service-row{
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
  padding:46px 0;border-top:1px solid var(--line);
}
.service-row:first-of-type{border-top:none}
.service-row.reverse{grid-template-columns:1fr 1.1fr}
.service-row.reverse .service-copy{order:2}
.service-copy .num{
  font-family:"Fraunces",serif;color:var(--purple);font-size:.9rem;letter-spacing:.12em;
}
.service-copy h3{font-size:2rem;margin:6px 0 14px}
.service-copy ul{padding:0;list-style:none;margin:18px 0 0}
.service-copy li{display:flex;gap:12px;align-items:flex-start;padding:8px 0;color:var(--ink);font-size:.98rem}
.service-copy li::before{
  content:"";flex:none;margin-top:10px;width:8px;height:8px;border-radius:2px;
  background:var(--purple);transform:rotate(45deg);
}
.service-img{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:4/3;
}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.service-img:hover img{transform:scale(1.04)}
.service-img .tag{
  position:absolute;left:18px;bottom:18px;
  background:rgba(30,10,55,.8);backdrop-filter:blur(8px);color:#fff;
  padding:8px 14px;border-radius:999px;font-size:.82rem;letter-spacing:.04em;
}
@media(max-width:820px){
  .service-row,.service-row.reverse{grid-template-columns:1fr;gap:28px}
  .service-row.reverse .service-copy{order:0}
}

/* ---------- Gallery ---------- */
.gallery{background:var(--purple-50)}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:180px;gap:16px}
.g-item{position:relative;overflow:hidden;border-radius:18px;cursor:pointer;background:#111}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s, opacity .4s}
.g-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,10,55,.8) 0%,transparent 55%);opacity:.9;
}
.g-item .cap{position:absolute;left:18px;right:18px;bottom:16px;color:#fff;z-index:2}
.g-item .cap h4{color:#fff;font-family:"Fraunces",serif;font-size:1.15rem;margin:0 0 2px}
.g-item .cap span{font-size:.8rem;color:var(--purple-300);letter-spacing:.04em}
.g-item:hover img{transform:scale(1.05)}
.g-1{grid-column:span 7;grid-row:span 2}
.g-2{grid-column:span 5;grid-row:span 1}
.g-3{grid-column:span 5;grid-row:span 1}
.g-4{grid-column:span 4;grid-row:span 2}
.g-5{grid-column:span 4;grid-row:span 1}
.g-6{grid-column:span 4;grid-row:span 1}
@media(max-width:820px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-1,.g-2,.g-3,.g-4,.g-5,.g-6{grid-column:span 1;grid-row:span 1}
  .g-1{grid-column:span 2}
}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--cream)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.tcard{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px;display:flex;flex-direction:column;gap:18px;transition:transform .25s;
}
.tcard:hover{transform:translateY(-3px)}
.stars{color:var(--gold);letter-spacing:2px;font-size:1.1rem}
.tcard blockquote{margin:0;font-family:"Fraunces",serif;font-size:1.08rem;color:var(--ink);line-height:1.5}
.tmeta{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.tmeta .avatar{
  width:44px;height:44px;border-radius:50%;background:var(--purple-100);
  display:grid;place-items:center;font-family:"Fraunces",serif;font-weight:700;color:var(--purple);
}
.tmeta .who strong{display:block;color:var(--ink)}
.tmeta .who span{font-size:.85rem;color:var(--muted)}
@media(max-width:820px){.tgrid{grid-template-columns:1fr}}

/* ---------- About ---------- */
.values-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px;
}
.vitem{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;display:flex;gap:16px;align-items:flex-start;
}
.vitem .dot{
  flex:none;width:42px;height:42px;border-radius:12px;background:var(--purple-100);
  display:grid;place-items:center;color:var(--purple);
}
.vitem .dot svg{width:22px;height:22px}
.vitem h4{margin:0 0 6px;font-size:1.05rem;color:var(--ink)}
.vitem p{margin:0;color:var(--muted);font-size:.95rem}
@media(max-width:720px){.values-list{grid-template-columns:1fr}}

.leaders{background:var(--purple-50)}
.leader-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:30px;
}
.leader{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;transition:transform .25s, box-shadow .25s;
}
.leader:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.leader img{width:100%;aspect-ratio:4/5;object-fit:cover}
.leader .lb{padding:18px 20px}
.leader h4{margin:0;font-size:1.05rem}
.leader span{font-size:.85rem;color:var(--muted)}
@media(max-width:900px){.leader-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.leader-grid{grid-template-columns:1fr}}

/* ---------- Benefits (careers) ---------- */
.benefits-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px;
}
.benefit{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px;display:flex;flex-direction:column;gap:12px;
  transition:transform .25s, box-shadow .25s;
}
.benefit:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.benefit .ico{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(135deg,var(--purple-100),var(--purple-50));
  color:var(--purple);display:grid;place-items:center;
}
.benefit .ico svg{width:26px;height:26px}
.benefit h4{margin:0;font-size:1.1rem}
.benefit span{color:var(--muted);font-size:.9rem}
@media(max-width:820px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.benefits-grid{grid-template-columns:1fr}}

.positions{background:var(--purple-50)}
.pos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}
.pos{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;text-align:center;font-weight:600;color:var(--ink);
  transition:transform .2s, border-color .2s;
}
.pos:hover{border-color:var(--purple);transform:translateY(-2px)}
@media(max-width:820px){.pos-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Forms ---------- */
.formsection{background:linear-gradient(180deg,var(--cream) 0%,var(--purple-50) 100%)}
.quote-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:60px;align-items:start}
.perks{margin:20px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.perks li{display:flex;gap:12px;align-items:center;color:var(--ink);font-weight:500}
.perks svg{width:22px;height:22px;color:var(--purple);flex:none}

form.app-form,
form.quote-form{
  background:#fff;padding:38px;border-radius:var(--radius-lg);
  border:1px solid var(--line);box-shadow:var(--shadow);
  display:grid;gap:16px;
}
.form-group{border:1px solid var(--line);padding:20px;border-radius:var(--radius)}
.form-group > h4{
  margin:0 0 14px;font-family:"Inter",sans-serif;font-weight:700;
  font-size:.85rem;color:var(--purple);letter-spacing:.08em;text-transform:uppercase;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-row.triple{grid-template-columns:1fr 1fr 1fr}
.field label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--muted);margin-bottom:6px;text-transform:uppercase}
.field .req{color:var(--purple)}
.field input,
.field select,
.field textarea{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);
  transition:border-color .2s, background .2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{outline:none;border-color:var(--purple);background:#fff}
.field textarea{min-height:110px;resize:vertical}
.radio-row{display:flex;gap:22px;margin-top:4px}
.radio-row label{display:inline-flex;align-items:center;gap:8px;font-weight:500;color:var(--ink);text-transform:none;letter-spacing:0;font-size:.95rem}
.radio-row input{width:auto;margin:0}
.consent{
  display:flex;gap:10px;align-items:flex-start;padding:14px;
  background:var(--purple-50);border-radius:10px;font-size:.85rem;color:var(--ink);
}
.consent input{width:auto;margin-top:3px}
form .btn-primary{justify-content:center;padding:16px;font-size:1rem}
.form-foot{font-size:.82rem;color:var(--muted);text-align:center;margin:4px 0 0}
.form-success{
  display:none;padding:16px;background:#e8f7ec;border:1px solid #8fc896;
  border-radius:10px;color:#20623d;font-weight:500;
}
form.is-sent .form-success{display:block}
form.is-sent button[type=submit]{background:#20623d}
@media(max-width:820px){
  .quote-grid{grid-template-columns:1fr}
  .field-row,.field-row.triple{grid-template-columns:1fr}
  form.app-form,form.quote-form{padding:26px}
}

/* ---------- Contact cards ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:10px}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px;display:flex;flex-direction:column;gap:8px;
}
.contact-card h3{margin:0 0 2px}
.contact-card .loc{color:var(--purple);font-weight:600}
.contact-card ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:10px;color:var(--ink)}
.contact-card ul li{display:flex;gap:10px;align-items:flex-start;color:var(--ink)}
.contact-card svg{width:20px;height:20px;color:var(--purple);flex:none;margin-top:3px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ---------- About featured strip ---------- */
.mission{background:var(--purple-deep);color:#efe3ff}
.mission h2,.mission h3{color:#fff}
.mission p{color:rgba(255,255,255,.82);font-size:1.05rem}
.mission .about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.mission .meet{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:28px;
}
.mission .meet img{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid var(--gold)}
.mission .meet h4{color:#fff;margin:14px 0 4px}
.mission .meet span{color:var(--gold);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}
@media(max-width:820px){.mission .about-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
footer{background:var(--purple-deep);color:#c9b8e0;padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
footer h5{color:#fff;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;margin:0 0 14px;font-weight:700;font-family:"Inter",sans-serif}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
footer a{color:#c9b8e0;font-size:.95rem}
footer a:hover{color:#fff}
.foot-brand img{max-height:64px;width:auto;margin-bottom:12px;background:#fff;padding:8px 12px;border-radius:8px;display:inline-block}
.foot-brand p{color:rgba(201,184,224,.75);max-width:38ch;margin-top:6px}
.foot-bottom{
  margin-top:50px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  color:rgba(201,184,224,.6);font-size:.85rem;
}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:540px){.foot-grid{grid-template-columns:1fr}}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s, transform .8s}
.reveal.in{opacity:1;transform:none}

/* ---------- Small helpers ---------- */
.center{text-align:center}
.mt-40{margin-top:40px}
.mt-60{margin-top:60px}
.muted{color:var(--muted)}
.accent{color:var(--purple)}
.small{font-size:.85rem}

/* ---------- Contact page ---------- */
.contact-section{padding:80px 0}
.contact-section .contact-grid{
  grid-template-columns:.9fr 1.3fr;gap:40px;align-items:start;margin-top:0;
}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-info .contact-card h4{
  margin:0 0 6px;font-size:1.05rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--purple);font-family:"Inter",sans-serif;font-weight:700;
}
.contact-info .contact-card p{margin:0 0 4px;color:var(--ink)}
.contact-info .contact-card p.muted{color:var(--muted);font-size:.9rem}
.contact-info .contact-card .addr{color:var(--ink)}
.contact-form-wrap{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:36px;
}
.form-intro{margin-bottom:22px}
.form-intro h2{margin:0 0 6px;font-size:1.6rem}
.form-intro p{margin:0;color:var(--muted)}
.site-form{display:flex;flex-direction:column;gap:16px}
.site-form label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--ink);font-weight:500}
.site-form label > span{color:var(--ink);font-weight:500}
.site-form input,.site-form select,.site-form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.98rem;background:#fff;color:var(--ink);
  transition:border-color .15s, box-shadow .15s;
}
.site-form input:focus,.site-form select:focus,.site-form textarea:focus{
  outline:none;border-color:var(--purple);box-shadow:0 0 0 3px var(--purple-100);
}
.site-form textarea{resize:vertical;min-height:120px}
.form-actions{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.form-actions .btn-primary{align-self:flex-start;padding:14px 28px}
.form-actions .muted{margin:0}
@media(max-width:900px){
  .contact-section .contact-grid{grid-template-columns:1fr}
  .contact-form-wrap{padding:26px}
}

/* ---------- Mission strip (dark purple band) ---------- */
.mission-strip{background:var(--purple-deep);color:#efe3ff;padding:80px 0}
.mission-strip h2{color:#fff;max-width:22ch}
.mission-strip p{color:rgba(255,255,255,.82);max-width:58ch;font-size:1.05rem}
.mission-strip .eyebrow{color:var(--purple-300)}
.mission-strip .eyebrow.light{color:var(--purple-300)}
.mission-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:center}
.mission-photo img{width:100%;border-radius:var(--radius-lg);object-fit:cover;aspect-ratio:4/3}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;
  border:1px solid rgba(255,255,255,.3);border-radius:999px;color:#fff;
  font-weight:600;margin-top:18px;transition:background .15s, border-color .15s;
}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5);color:#fff}

/* ---------- Workforce banner (About page) ---------- */
.workforce-banner{padding:40px 0 60px}
.workforce-banner figure{margin:0;position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.workforce-banner figure img{width:100%;height:auto;display:block;aspect-ratio:21/9;object-fit:cover}
.workforce-banner figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:28px 34px;
  background:linear-gradient(to top, rgba(42,8,68,.92) 0%, rgba(42,8,68,.72) 50%, rgba(42,8,68,0) 100%);
  color:#fff;
}
.workforce-banner figcaption .eyebrow{color:var(--purple-300);display:block;margin-bottom:6px}
.workforce-banner figcaption h3{color:#fff;margin:0 0 6px;font-size:clamp(1.4rem,2.8vw,2.2rem)}
.workforce-banner figcaption p{color:rgba(255,255,255,.9);margin:0;max-width:60ch}
@media(max-width:700px){
  .workforce-banner figure img{aspect-ratio:4/3}
  .workforce-banner figcaption{padding:18px 20px;position:relative;background:var(--purple-deep)}
}
@media(max-width:820px){.mission-inner{grid-template-columns:1fr;gap:30px}}
