/* ==========================================================================
   Axceltrees Consulting - design system (editorial / authority register)
   One stylesheet, custom properties, hand-built. Palette from the palm-tree logo.
   All colour pairs verified with tools/contrast-audit.mjs (WCAG 2.1 AA).
   ========================================================================== */

/* ----- Fonts (self-hosted woff2, latin subset) ---------------------------- */
@font-face{font-family:"Playfair Display";font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/playfair-display-600.woff2") format("woff2")}
@font-face{font-family:"Playfair Display";font-style:normal;font-weight:700;font-display:swap;
  src:url("../fonts/playfair-display-700.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/source-sans-3-400.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/source-sans-3-600.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:700;font-display:swap;
  src:url("../fonts/source-sans-3-700.woff2") format("woff2")}

/* ----- Design tokens ------------------------------------------------------ */
:root{
  /* brand palette (from the logo) */
  --ink:#16252b;            /* primary text on light */
  --ink-soft:#41535a;       /* muted text on light (AA body) */
  --brand:#0c4a5a;          /* deep petrol teal (trunk) */
  --brand-deep:#093744;     /* darkest teal (hero/footer) */
  --accent:#bd4b2c;         /* terracotta coral (frond), button-safe */
  --accent-ink:#a8431e;     /* coral for text/links on light */
  --gold:#c9a227;           /* muted gold (decorative accents only) */
  --leaf:#1e7a53;           /* deep green (decorative / large accents) */
  --paper:#f8f6f1;          /* warm ivory field */
  --surface:#ffffff;        /* card / panel */
  --surface-2:#f1ede4;      /* subtle alt fill */
  --line:#e4e0d6;           /* hairline borders */
  --line-strong:#cfc8b8;
  /* on-dark tokens */
  --on-dark:#ffffff;
  --muted-on-dark:#b9c9ce;
  --accent-on-dark:#f0a98e;
  --line-on-dark:rgba(255,255,255,.18);

  /* type scale (clamp) */
  --f-display:clamp(2.4rem,1.6rem + 3.4vw,4rem);
  --f-h1:clamp(2rem,1.45rem + 2.4vw,3.1rem);
  --f-h2:clamp(1.6rem,1.25rem + 1.5vw,2.3rem);
  --f-h3:clamp(1.2rem,1.05rem + .6vw,1.45rem);
  --f-lead:clamp(1.075rem,1rem + .35vw,1.3rem);
  --f-body:1.0625rem;
  --f-sm:.9375rem;
  --f-eyebrow:.78rem;

  /* spacing / layout */
  --container:1180px;
  --container-narrow:880px;
  --gap:clamp(1.25rem,1rem + 1.5vw,2rem);
  --section-y:clamp(3.5rem,2.4rem + 4vw,6rem);
  --radius:14px;
  --radius-sm:9px;
  --radius-lg:22px;

  /* effects */
  --shadow-sm:0 1px 2px rgba(9,55,68,.06),0 2px 8px rgba(9,55,68,.05);
  --shadow:0 6px 20px rgba(9,55,68,.08),0 2px 6px rgba(9,55,68,.05);
  --shadow-lg:0 22px 50px rgba(9,55,68,.16);
  --ring:0 0 0 3px rgba(189,75,44,.45);
  --ease:cubic-bezier(.22,.61,.36,1);

  /* lightbox aliases (kit gallery-carousel.css) */
  --lb-accent:var(--accent-on-dark);
  --lb-muted:var(--muted-on-dark);
}

/* ----- Reset / base ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:104px}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:"Source Sans 3",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:var(--f-body);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--accent-ink)}
strong{font-weight:700}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0}
ul,ol{padding-left:1.2em}

h1,h2,h3,h4{font-family:"Playfair Display",Georgia,serif;font-weight:700;line-height:1.14;
  color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:var(--f-h1)}
h2{font-size:var(--f-h2)}
h3{font-size:var(--f-h3);font-weight:600}
p{margin:0 0 1rem}
p:last-child{margin-bottom:0}

:focus-visible{outline:none;box-shadow:var(--ring);border-radius:4px}

/* ----- Accessibility helpers --------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0}
.skip-link{position:absolute;left:12px;top:-48px;z-index:1200;background:var(--brand);color:#fff;
  padding:.6rem 1rem;border-radius:0 0 8px 8px;font-weight:600;transition:top .2s}
.skip-link:focus{top:0;color:#fff}

/* ----- Layout ------------------------------------------------------------- */
.container{width:min(100% - 2.5rem,var(--container));margin-inline:auto}
.container-narrow{width:min(100% - 2.5rem,var(--container-narrow));margin-inline:auto}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(2.25rem,1.6rem + 2vw,3.25rem)}
.section--paper{background:var(--paper)}
.section--surface{background:var(--surface)}
.section--alt{background:var(--surface-2)}
.section--teal{background:var(--brand);color:var(--on-dark)}
.section--deep{background:var(--brand-deep);color:var(--on-dark)}

/* dark-section defaults (component-not-container: never touch .eyebrow here) */
.section--teal h1,.section--teal h2,.section--teal h3,.section--teal h4,
.section--deep h1,.section--deep h2,.section--deep h3,.section--deep h4{color:var(--on-dark)}
.section--teal p:not(.eyebrow),.section--deep p:not(.eyebrow){color:var(--muted-on-dark)}
.section--teal a:not(.btn):not(.brand),.section--deep a:not(.btn):not(.brand){color:var(--on-dark);
  text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-on-dark)}

.grid{display:grid;gap:var(--gap)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* ----- Eyebrow + section head + signature "branch" rule ------------------ */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;margin:0 0 .9rem;
  font-family:"Source Sans 3",sans-serif;font-size:var(--f-eyebrow);font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent-ink)}
.section--teal .eyebrow,.section--deep .eyebrow,.hero .eyebrow,.cta-band .eyebrow,
.page-hero .eyebrow{color:var(--accent-on-dark)}
/* the branch: a short growing rule with a leaf node (palm-tree growth motif) */
.branch{display:inline-block;width:34px;height:2px;background:var(--accent);position:relative;border-radius:2px}
.branch::after{content:"";position:absolute;right:-3px;top:-2px;width:6px;height:6px;border-radius:50%;
  background:var(--leaf)}
.section--teal .branch,.section--deep .branch,.hero .branch,.cta-band .branch,.page-hero .branch{background:var(--accent-on-dark)}
.section--teal .branch::after,.section--deep .branch::after,.hero .branch::after,
.cta-band .branch::after,.page-hero .branch::after{background:var(--gold)}

.section-head{max-width:62ch}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .lead{font-size:var(--f-lead);color:var(--ink-soft)}
.section--teal .section-head .lead,.section--deep .section-head .lead{color:var(--muted-on-dark)}

/* oversized faint serif index numeral (signature) */
.index-num{font-family:"Playfair Display",serif;font-weight:700;font-size:clamp(2.4rem,4vw,3.4rem);
  line-height:1;color:var(--accent);opacity:.22}
.section--teal .index-num,.section--deep .index-num{color:var(--accent-on-dark);opacity:.5}

/* ----- Buttons ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;
  font-family:"Source Sans 3",sans-serif;font-size:1rem;font-weight:700;line-height:1.1;
  padding:.85rem 1.5rem;border-radius:999px;border:2px solid transparent;transition:transform .15s var(--ease),
  background-color .2s,box-shadow .2s,border-color .2s;text-align:center}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(189,75,44,.28)}
.btn-primary:hover{background:#a8431e;color:#fff}
.btn-secondary{background:transparent;color:var(--brand);border-color:var(--line-strong)}
.btn-secondary:hover{color:var(--brand);border-color:var(--brand);background:rgba(12,74,90,.05)}
.btn-ghost{background:var(--surface);color:var(--brand);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{color:var(--accent-ink);border-color:var(--line-strong)}
.btn-block{display:flex;width:100%}
/* on-dark button variants */
.section--teal .btn-secondary,.section--deep .btn-secondary,.hero .btn-secondary,
.cta-band .btn-secondary,.page-hero .btn-secondary{color:#fff;border-color:rgba(255,255,255,.55)}
.section--teal .btn-secondary:hover,.section--deep .btn-secondary:hover,.hero .btn-secondary:hover,
.cta-band .btn-secondary:hover,.page-hero .btn-secondary:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem}
.btn-row.center{justify-content:center}

/* ----- Header / nav ------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .2s,background .2s}
.site-header.scrolled{background:rgba(255,255,255,.98);box-shadow:0 4px 18px rgba(9,55,68,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:90px;padding-block:.2rem}
.brand{display:inline-flex;align-items:center;flex:0 0 auto}
.brand img{height:78px;width:auto;display:block}
.primary-nav{display:flex;align-items:center;justify-content:flex-end;gap:.1rem;flex:1;margin-left:1.5rem}
.primary-nav a.navlink{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .7rem;border-radius:8px;
  color:var(--brand);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.07em;
  transition:color .15s,background .15s}
.primary-nav a.navlink:hover{color:var(--accent-ink);background:rgba(12,74,90,.06)}
.primary-nav a.navlink[aria-current="page"],.navlink--current{color:var(--accent-ink)}
.navlink--current{position:relative}
.navlink--current::before{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.28rem;height:2px;
  background:var(--accent);border-radius:2px}
.header-cta{display:flex;align-items:center;gap:.6rem}

/* dropdown */
.has-submenu{position:relative}
.submenu-toggle{background:none;border:0;font:inherit;cursor:pointer}
.submenu{position:absolute;left:0;top:calc(100% + 10px);min-width:230px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:.5rem;
  list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .18s,transform .18s,visibility .18s;z-index:1001}
.submenu::before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px}/* hover bridge */
.has-submenu:hover .submenu,.has-submenu:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:.6rem .8rem;border-radius:8px;color:var(--ink);font-weight:600;font-size:.95rem}
.submenu a:hover{background:rgba(12,74,90,.07);color:var(--accent-ink)}

/* mobile menu */
.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:46px;border-radius:10px;
  border:1px solid var(--line);background:var(--surface);cursor:pointer}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:22px;height:2px;
  background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s;position:relative}
.nav-toggle span::before{position:absolute;top:-7px}
.nav-toggle span::after{position:absolute;top:7px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{transform:translateY(-7px) rotate(-45deg)}

@media(max-width:1080px){
  .nav-toggle{display:inline-flex}
  .primary-nav{position:fixed;inset:90px 0 auto 0;flex-direction:column;align-items:stretch;gap:.15rem;
    margin-left:0;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    padding:1rem 1.25rem 1.6rem;max-height:calc(100vh - 90px);overflow:auto;
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:transform .22s,opacity .22s,visibility .22s}
  .primary-nav.open{transform:translateY(0);opacity:1;visibility:visible}
  .primary-nav a.navlink{padding:.85rem .4rem;font-size:14px;border-bottom:1px solid var(--line)}
  .navlink--current::before{display:none}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    padding:.2rem 0 .2rem 1rem;min-width:0}
  .submenu::before{display:none}
  /* CTAs move to the bottom of the open menu, stacked and centered (Request talent is the prominent one) */
  .primary-nav .header-cta{margin:1.2rem 0 0;width:100%;flex-direction:column;align-items:stretch;gap:.7rem;
    padding-top:1.3rem;border-top:1px solid var(--line)}
  .primary-nav .header-cta .btn{width:100%;justify-content:center;font-size:1rem;padding:.9rem 1.5rem}
}
/* JS-off: nav is always visible (no fixed overlay) */
.no-js .primary-nav{position:static;flex-direction:row;flex-wrap:wrap;opacity:1;visibility:visible;
  transform:none;background:none;box-shadow:none;border:0;padding:0;max-height:none}
.no-js .nav-toggle{display:none}

/* ----- Hero --------------------------------------------------------------- */
.hero{position:relative;background:var(--brand-deep);color:var(--on-dark);overflow:hidden;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(9,55,68,.93) 0%,rgba(9,55,68,.82) 46%,rgba(9,55,68,.55) 100%)}
.hero-inner{padding-block:clamp(3.5rem,2.5rem + 6vw,6.5rem);max-width:760px}
.hero h1{color:#fff;font-size:var(--f-display);margin-bottom:.6rem}
.hero .hero-lead{font-size:var(--f-lead);color:#e7eef0;max-width:60ch;margin-bottom:1.6rem}
.hero .btn-row{margin-top:.4rem}
.hero-strip{display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem;margin-top:2.4rem;padding-top:1.6rem;
  border-top:1px solid var(--line-on-dark)}
.hero-strip .stat b{display:block;font-family:"Playfair Display",serif;font-size:1.9rem;color:#fff;line-height:1}
.hero-strip .stat span{font-size:.9rem;color:var(--muted-on-dark)}

/* ----- Page hero (inner pages) ------------------------------------------- */
.page-hero{position:relative;background:var(--brand);color:var(--on-dark);overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:320px;height:320px;
  background:radial-gradient(circle,rgba(232,150,122,.22),rgba(12,74,90,0) 70%);z-index:0}
.page-hero .container{position:relative;z-index:1}
.page-hero-inner{padding-block:clamp(2.5rem,2rem + 3.5vw,4rem);max-width:720px}
.page-hero h1{color:#fff;font-size:var(--f-h1);margin-bottom:.5rem}
.page-hero p{color:#e7eef0;font-size:var(--f-lead)}
.breadcrumb{font-size:.85rem;color:var(--muted-on-dark);margin-bottom:1rem}
.breadcrumb a{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-on-dark)}
.breadcrumb span[aria-current]{color:var(--muted-on-dark)}

/* ----- Stats / trust strip ------------------------------------------------ */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);text-align:center}
@media(max-width:760px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat-card b{display:block;font-family:"Playfair Display",serif;font-size:clamp(1.9rem,1.4rem + 1.6vw,2.7rem);
  color:var(--brand);line-height:1}
.section--teal .stat-card b,.section--deep .stat-card b{color:#fff}
.stat-card span{display:block;margin-top:.35rem;font-size:.95rem;color:var(--ink-soft);font-weight:600}
.section--teal .stat-card span,.section--deep .stat-card span{color:var(--muted-on-dark)}

/* ----- Cards -------------------------------------------------------------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.card h3{margin-bottom:.4rem}
.card p{color:var(--ink-soft);font-size:var(--f-sm)}
/* white cards keep DARK headings even inside dark sections */
.section--teal .card h3,.section--deep .card h3{color:var(--ink)}
.section--teal .card p,.section--deep .card p{color:var(--ink-soft)}

.ico{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:12px;
  background:rgba(12,74,90,.08);color:var(--brand);margin-bottom:1rem}
.ico svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.7;
  stroke-linecap:round;stroke-linejoin:round}
.ico--accent{background:rgba(189,75,44,.1);color:var(--accent-ink)}
.ico--leaf{background:rgba(30,122,83,.1);color:var(--leaf)}

.card-num{display:flex;gap:1rem;align-items:flex-start}
.card-num .index-num{flex:0 0 auto}

/* feature list with check marks */
.checklist{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
.checklist li{position:relative;padding-left:1.9rem;color:var(--ink-soft)}
.checklist li::before{content:"";position:absolute;left:0;top:.15em;width:1.25rem;height:1.25rem;border-radius:50%;
  background:rgba(30,122,83,.12);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%231e7a53' d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/%3E%3C/svg%3E") center/72% no-repeat,linear-gradient(#1e7a53,#1e7a53);
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/%3E%3C/svg%3E") center/72% no-repeat}
.section--teal .checklist li,.section--deep .checklist li{color:var(--muted-on-dark)}
.checklist.on-dark li::before{background:rgba(232,150,122,.2)}

/* ----- Split image + text ------------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,1rem + 3vw,3.5rem);align-items:center}
.split.reverse .split-media{order:2}
@media(max-width:860px){.split{grid-template-columns:1fr}.split.reverse .split-media{order:0}}
.split-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:5/4}
.split-media.framed{border:1px solid var(--line);background:var(--surface)}
/* brand illustrations (flat SVGs): no frame, just the art */
.illus{width:100%;max-width:480px;height:auto;display:block;margin-inline:auto}
.split.reverse .illus-col{order:2}
@media(max-width:860px){.split.reverse .illus-col{order:0}}

/* ----- Audience cards (employers / candidates split) --------------------- */
.audience{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
@media(max-width:780px){.audience{grid-template-columns:1fr}}
.audience-card{position:relative;border-radius:var(--radius-lg);padding:2rem;overflow:hidden;
  border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:.5rem}
.audience-card.is-employer{background:linear-gradient(160deg,#0c4a5a,#093744);color:#fff;border-color:transparent}
.audience-card.is-employer h3,.audience-card.is-employer p{color:#fff}
.audience-card.is-employer p{color:#dbe6e9}
.audience-card .btn{margin-top:auto}

/* ----- Team grid ---------------------------------------------------------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}}
.team-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);text-align:left}
.team-photo{aspect-ratio:1/1;background:var(--surface-2);overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.team-body{padding:1rem 1.1rem 1.2rem}
.team-body h3{font-size:1.08rem;margin-bottom:.1rem}
.team-role{font-size:.85rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-ink);margin:0 0 .5rem}
.team-contact{list-style:none;padding:0;margin:.5rem 0 .8rem;display:grid;gap:.4rem}
.team-contact a{display:inline-flex;align-items:center;gap:.45rem;color:var(--ink-soft);font-size:.84rem;
  font-weight:600;line-height:1.3;overflow-wrap:anywhere}
.team-contact a:hover{color:var(--accent-ink)}
.team-contact svg{width:15px;height:15px;flex:0 0 auto;color:var(--brand)}
.team-li{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;
  border:1px solid var(--line);color:var(--brand);background:var(--surface);
  transition:background .15s,color .15s,border-color .15s}
.team-li:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.team-li svg{width:17px;height:17px;fill:currentColor}

/* ----- Job / openings list ----------------------------------------------- */
.jobs{display:grid;gap:1rem}
.job{display:grid;grid-template-columns:1fr auto;gap:1rem 1.5rem;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:var(--radius);padding:1.3rem 1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}
.job:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.job h3{margin:0 0 .35rem;font-size:1.15rem}
.job-meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;font-size:.9rem;color:var(--ink-soft)}
.job-meta span{display:inline-flex;align-items:center;gap:.35rem}
.tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.25rem .6rem;border-radius:999px;background:rgba(12,74,90,.08);color:var(--brand)}
.tag.tag-loc{background:rgba(189,75,44,.1);color:var(--accent-ink)}
@media(max-width:560px){.job{grid-template-columns:1fr}.job .btn{justify-self:start}}

/* ----- Clients logo wall -------------------------------------------------- */
.logo-wall{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}
@media(max-width:900px){.logo-wall{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.logo-wall{grid-template-columns:repeat(3,1fr)}}
.logo-cell{display:flex;align-items:center;justify-content:center;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:1rem;aspect-ratio:3/2}
.logo-cell img{max-height:60px;width:auto;filter:saturate(.2) opacity(.85);transition:filter .2s}
.logo-cell:hover img{filter:none}

/* ----- Quote / pull ------------------------------------------------------- */
.pull{font-family:"Playfair Display",serif;font-size:clamp(1.3rem,1.05rem + 1vw,1.9rem);line-height:1.35;
  color:var(--ink);font-weight:600}
.section--teal .pull,.section--deep .pull{color:#fff}

/* ----- CTA band ----------------------------------------------------------- */
.cta-band{position:relative;background:linear-gradient(150deg,#0c4a5a,#093744);color:#fff;overflow:hidden}
.cta-band::before{content:"";position:absolute;left:-40px;bottom:-60px;width:280px;height:280px;
  background:radial-gradient(circle,rgba(232,150,122,.25),rgba(12,74,90,0) 70%)}
.cta-band .container{position:relative;z-index:1}
.cta-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem}
.cta-inner h2{color:#fff;margin-bottom:.4rem;max-width:22ch}
.cta-inner p{color:#dbe6e9;max-width:46ch}

/* ----- Enquiry starters (mailto, no forms) ------------------------------- */
.starter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
@media(max-width:780px){.starter-grid{grid-template-columns:1fr}}
.starter{display:flex;flex-direction:column;gap:.5rem;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s}
.starter:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.starter h3{margin:0;font-size:1.12rem}
.starter p{color:var(--ink-soft);font-size:var(--f-sm);flex:1}
.starter .btn{align-self:flex-start;margin-top:.3rem}

/* contact rows */
.contact-rows{display:grid;gap:1rem}
.contact-row{display:flex;gap:1rem;align-items:flex-start;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.1rem 1.3rem;box-shadow:var(--shadow-sm)}
.contact-row .ico{margin-bottom:0;width:44px;height:44px;flex:0 0 auto}
.contact-row .ico svg{width:22px;height:22px}
.contact-row h3{font-size:1rem;margin:0 0 .15rem}
.contact-row a,.contact-row p{font-size:.97rem;color:var(--ink-soft);margin:0}
.contact-row a{color:var(--brand);font-weight:600}
.contact-row a:hover{color:var(--accent-ink)}
.map-frame{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.map-frame iframe{display:block;width:100%;height:340px;border:0}

/* ----- FAQ (native details) ---------------------------------------------- */
.faq{display:grid;gap:.85rem;max-width:820px;margin-inline:auto}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 3rem 1.1rem 1.3rem;position:relative;
  font-family:"Playfair Display",serif;font-weight:600;font-size:1.08rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";position:absolute;right:1.2rem;top:1.35rem;width:13px;height:13px;
  border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(45deg);
  transition:transform .2s}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq summary:focus-visible{box-shadow:var(--ring)}
.faq-a{padding:0 1.3rem 1.2rem;color:var(--ink-soft)}
.faq-a p{margin-bottom:.6rem}

/* ----- Prose -------------------------------------------------------------- */
.prose{max-width:70ch}
.prose h2{margin-top:2rem}
.prose h3{margin-top:1.4rem}
.prose ul{display:grid;gap:.5rem;color:var(--ink-soft)}

/* ----- Footer ------------------------------------------------------------- */
.site-footer{background:var(--brand-deep);color:var(--muted-on-dark);padding-block:clamp(2.5rem,2rem + 2vw,3.5rem) 1.5rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2rem}
@media(max-width:880px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand .brand{margin-bottom:1rem;align-self:flex-start;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:10px 14px;box-shadow:var(--shadow-sm)}
.footer-brand .brand img{height:74px}
.footer-brand p{font-size:.92rem;color:var(--muted-on-dark);max-width:34ch}
.footer-col h4{font-family:"Source Sans 3",sans-serif;font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;
  color:#fff;margin:0 0 1rem;font-weight:700}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.footer-col a{color:var(--muted-on-dark);font-size:.95rem}
.footer-col a:hover{color:#fff}
.footer-contact a{color:var(--muted-on-dark)}
.social-row{display:flex;gap:.6rem;margin-top:.4rem}
.social-row a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;
  border:1px solid var(--line-on-dark);color:#fff;background:rgba(255,255,255,.04)}
.social-row a:hover{background:var(--accent);border-color:var(--accent)}
.social-row svg{width:19px;height:19px;fill:currentColor}
.footer-standards{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:2rem;padding-top:1.4rem;
  border-top:1px solid var(--line-on-dark);font-size:.82rem;color:var(--muted-on-dark)}
.footer-standards span{display:inline-flex;align-items:center;gap:.4rem}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;margin-top:1.4rem;
  font-size:.85rem;color:var(--muted-on-dark)}
.footer-bottom a{color:#fff}

/* ----- Floating WhatsApp -------------------------------------------------- */
.float-wa{position:fixed;right:18px;bottom:18px;z-index:900;display:inline-flex;align-items:center;gap:.5rem;
  background:#1e7a53;color:#fff;padding:.7rem 1.05rem;border-radius:999px;font-weight:700;font-size:.95rem;
  box-shadow:0 10px 24px rgba(9,55,68,.28);transition:transform .15s,background .2s}
.float-wa:hover{transform:translateY(-2px);background:#176a47;color:#fff}
.float-wa svg{width:20px;height:20px;fill:currentColor}
@media(max-width:560px){.float-wa span{display:none}.float-wa{padding:.85rem;border-radius:50%}}

/* ----- Notes / honesty callout ------------------------------------------- */
.note{background:rgba(201,162,39,.1);border:1px dashed var(--line-strong);border-radius:var(--radius);
  padding:1.1rem 1.3rem;font-size:var(--f-sm);color:var(--ink-soft)}
.note strong{color:var(--ink)}

/* ----- Reveal animation --------------------------------------------------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* JS-off: never hide content (the no-js class stays on <html> when JS is disabled) */
.no-js .reveal{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* ----- Misc utilities ----------------------------------------------------- */
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.lead{font-size:var(--f-lead);color:var(--ink-soft)}
.muted{color:var(--ink-soft)}
.stack>*+*{margin-top:1rem}
.divider-top{border-top:1px solid var(--line)}
.pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--brand);background:rgba(12,74,90,.07);padding:.3rem .7rem;border-radius:999px}
.section--teal .pill,.section--deep .pill,.cta-band .pill,.hero .pill{color:#fff;
  background:rgba(255,255,255,.14);border:1px solid var(--line-on-dark)}
/* pill placed on a translucent-white card that itself sits on a dark section */
.section--teal .card .pill,.section--deep .card .pill{color:#fff;background:rgba(255,255,255,.16);border:1px solid var(--line-on-dark)}
