

    :root{
      
      --header-h:72px;
      --brand-blue:#182D3A; /* RGB 24 45 58 */
      --brand-gold:#D8B25C; /* RGB 216 178 92 */
      --gold-50:#FFFBF0;
      --gold-100:#FFF2D6;
      --gold-200:#FDE6BF;
--accent: var(--brand-gold);
      --accent-soft: rgba(216,178,92,.12);
      --accent-strong: var(--brand-blue);
      --text-main:#111827;
      --text-muted:#6b7280;
      --border-subtle:rgba(148,163,184,.3);
      --shadow-soft:0 22px 60px rgba(15,23,42,.06);
      --shadow-strong:0 30px 90px rgba(15,23,42,.12);
      --transition-fast:180ms ease-out;
      --max-width:1120px;

      /* Cursor glow (updated by JS) */
      --glow-x: 20%;
      --glow-y: 25%;
    }

    *{box-sizing:border-box;margin:0;padding:0}
    html,body{height:100%;scroll-behavior:smooth}
    body{
      font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
      color:var(--text-main);
      -webkit-font-smoothing:antialiased;
      background:#fff;
          padding-top:var(--header-h);
    }

    /* NAVBAR */
    header{
      position:fixed;
      top:0;
      left:0;
      right:0;
      z-index:999;
      -webkit-backdrop-filter:blur(18px);
      backdrop-filter:blur(18px);
      transform:translateZ(0);
      background:rgba(24,45,58,.92);border-bottom:1px solid rgba(216,178,92,.22);}
    .nav-inner{
      max-width:var(--max-width);
      margin:0 auto;
      padding:.75rem 1.25rem;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:1.5rem;
      position:relative;
    }
    .brand{
      display:flex;
      align-items:center;
      gap:.65rem;
      min-width:220px;
    }
    .brand-image{height:40px;max-width:220px;width:auto;display:block}
    .brand-text{display:flex;flex-direction:column;line-height:1.1;white-space:nowrap}
    .brand-name{
      font-size:.9rem;
      font-weight:600;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:#ffffff;}
    .brand-tagline{
      margin-top:.12rem;
      font-size:.65rem;
      letter-spacing:.16em;
      text-transform:uppercase;
      color:rgba(255,255,255,.68);}

    .nav-toggle{
      display:none;
      background:none;
      border:none;
      color:#ffffff;
      font-size:1.4rem;
      cursor:pointer;
      line-height:1;
      padding:.4rem .6rem;
      border-radius:10px;
      transition:background var(--transition-fast);
    }
    .nav-toggle:hover{background:rgba(255,255,255,.08)}

    nav{
      display:flex;
      align-items:center;
      gap:1.5rem;
      font-size:.9rem;
    }
    .nav-links{display:flex;align-items:center;gap:1.4rem}
    nav a{
      color:rgba(255,255,255,.78);
      text-decoration:none;
      position:relative;
      padding-bottom:.2rem;
      transition:color var(--transition-fast);
    }
    nav a::after{
      content:"";
      position:absolute;
      left:0;
      bottom:-.22rem;
      width:0;
      height:2px;
      border-radius:999px;
      background:var(--accent);
      transition:width var(--transition-fast);
    }
    nav a:hover{color:#ffffff}
    nav a:hover::after{width:100%}
    nav a.is-active{color:#ffffff}
    nav a.is-active::after{width:100%}

    .nav-cta{
      padding:.55rem 1.2rem;
      border-radius:999px;
      border:1px solid rgba(216,178,92,.35);
      background:rgba(255,255,255,.06);
      color:var(--brand-gold);
      font-size:.8rem;
      font-weight:500;
      text-decoration:none;
      display:inline-flex;
      align-items:center;
      gap:.4rem;
      transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);
      box-shadow:0 0 0 rgba(0,0,0,0);
      white-space:nowrap;
    }
    .nav-cta span{font-size:1rem}
    .nav-cta:hover{background: rgba(216,178,92, .18);transform:translateY(-1px);border-color:rgba(216,178,92,.6);box-shadow:0 10px 25px rgba(0,0,0,.18);}

/* Enquiry CTA (end of page) */
.enquiry-panel{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.enquiry-note{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5}
.enquiry-cta{
  appearance:none;
  border:1px solid rgba(209,213,219,.9);
  background:linear-gradient(135deg,#fff,var(--gold-50));
  color:var(--accent-strong);
  border-radius:999px;
  padding:.75rem 1.25rem;
  font-size:.9rem;
  font-weight:600;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);
}
.enquiry-cta:hover{background:linear-gradient(135deg,#fff,var(--gold-100));transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:rgba(148,163,184,.95)}
.enquiry-cta:active{transform:translateY(0)}
.enquiry-cta:focus{outline:2px solid rgba(216,178,92,.35);outline-offset:3px}
.enquiry-microcopy{font-size:.85rem;color:var(--muted)}

    main{min-height:100vh}

    section[id]{scroll-margin-top:calc(var(--header-h) + 18px);}

    /* FULL-BLEED BANDS */
    .band{width:100%}
    .band-inner{
      max-width:var(--max-width);
      margin:0 auto;
      padding:0 1.25rem;
    }

    /* --------------------------------
       No-JS fallback: ALWAYS readable
       (prevents iPhone Safari blur)
    --------------------------------- */
    .band-content{
      opacity:1;
      transform:none;
      filter:none;
    }

    /* Only enable blur/reveal when JS is running */
    body.js .band-content{
      opacity:.18;
      transform:translateY(28px) scale(.985);
      filter:blur(7px) saturate(.78);
      transition:opacity 520ms ease,transform 520ms ease,filter 520ms ease;
      will-change:opacity,transform,filter;
    }
    body.js .band-content.in-view{
      opacity:1;
      transform:translateY(0) scale(1);
      filter:blur(0) saturate(1);
    }

    /* HERO BAND */
    .hero-band{
      background:
        radial-gradient(700px circle at 18% 12%, rgba(216,178,92,0.18) 0, transparent 55%),
        radial-gradient(900px circle at 78% 38%, rgba(24,45,58,0.06) 0, transparent 60%),
        linear-gradient(180deg, #f7f7f8 0%, #f2f3f5 100%);
      padding-top:5.4rem;
      padding-bottom:5.6rem;
      position:relative;
      overflow:hidden;
    }
    .hero-band::before{
      content:"";
      position:absolute;
      inset:0;
      background:
        linear-gradient(to right,rgba(17,24,39,.04) 1px,transparent 1px),
        linear-gradient(to bottom,rgba(17,24,39,.04) 1px,transparent 1px);
      background-size:64px 64px;
      mask-image:radial-gradient(circle at 22% 30%,rgba(0,0,0,.75),transparent 55%);
      pointer-events:none;
      opacity:.9;
    }
    .hero-band::after{
      content:"";
      position:absolute;
      inset:-20%;
      background:
        radial-gradient(circle at var(--glow-x) var(--glow-y),
          rgba(216,178,92,.16),
          transparent 48%);
      pointer-events:none;
      transition:opacity 220ms ease;
      opacity:1;
    }

    .hero-inner{
      display:grid;
      grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
      gap:3.4rem;
      align-items:start;
      position:relative;
      z-index:1;
    }

    /* Left stack */
    .hero-copy{
      max-width:42rem;
      display:flex;
      flex-direction:column;
    }

    /* Right stack aligns top w/ H1 and bottom w/ buttons */
    .hero-right{
      display:flex;
      flex-direction:column;
      align-self:stretch;
      height:100%;
      justify-content:space-between;
    }

    .hero-kicker{
      font-size:.78rem;
      letter-spacing:.22em;
      text-transform:uppercase;
      color: rgb(216,178,92);
      font-weight:500;
      display:inline-flex;
      align-items:center;
      gap:.4rem;
      padding:.28rem .8rem;
      border-radius:999px;
      border:1px solid rgba(216,178,92,.5);
      background: rgba(216,178,92, .18);
      backdrop-filter:blur(10px);
    }
    .pill-dot{width:6px;height:6px;border-radius:999px;background:var(--accent)}
    .hero-title{
      margin-top:1.65rem;
      font-size:clamp(2.85rem,4.9vw,3.9rem);
      line-height:1.02;
      letter-spacing:-.055em;
      font-weight:650;
      color:#0f172a;
    }
    .hero-title span{
      background:linear-gradient(120deg,#111827,var(--accent));
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
    }
    .hero-subtitle{
      margin-top:1.25rem;
      font-size:1.02rem;
      color:var(--text-muted);
      max-width:36rem;
      line-height:1.55;
    }
    .hero-subtitle strong{color:#111827;font-weight:500}

    .hero-actions{
      margin-top:2.35rem;
      display:flex;
      flex-wrap:wrap;
      gap:1rem;
      align-items:center;
    }
    .btn-primary{
      padding:1.02rem 1.75rem;
      border-radius:999px;
      border:none;
      background:var(--brand-blue);
      color:var(--gold-50);
      font-weight:600;
      font-size:.95rem;
      cursor:pointer;
      display:inline-flex;
      align-items:center;
      gap:.5rem;
      box-shadow:0 18px 50px rgba(24,45,58,.35);
      transition:transform var(--transition-fast),box-shadow var(--transition-fast),filter var(--transition-fast);
      text-decoration:none;
    }
    .btn-primary:hover{
      transform:translateY(-2px);
      box-shadow:0 26px 70px rgba(24,45,58,.45);
      filter:brightness(1.03);
    }
    .btn-secondary{
      padding:.98rem 1.4rem;
      border-radius:999px;
      border:1px solid rgba(209,213,219,.9);
      background:rgba(255,255,255,.85);
      color:var(--text-main);
      font-weight:500;
      font-size:.88rem;
      cursor:pointer;
      display:inline-flex;
      align-items:center;
      gap:.5rem;
      transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);
      text-decoration:none;
      backdrop-filter:blur(12px);
    }
    .btn-secondary:hover{
      background:rgba(249,250,251,.9);
      border-color:rgba(148,163,184,.9);
      box-shadow:0 12px 30px rgba(15,23,42,.08);
      transform:translateY(-1px);
    }

    /* HERO VISUAL */
    .hero-visual{
      position:relative;
      border-radius:34px;
      overflow:hidden;
      min-height:430px;
      box-shadow:var(--shadow-strong);
      background:
        radial-gradient(circle at 20% 15%,rgba(255,255,255,.85) 0,transparent 55%),
        radial-gradient(circle at 80% 70%,rgba(216,178,92,.24) 0,transparent 55%),
        linear-gradient(135deg,#fff 0%,#f5f5f7 55%,var(--gold-50) 100%);
      border:1px solid rgba(209,213,219,.75);
      display:flex;
      flex-direction:column;
      justify-content:space-between;
    }
    .hero-visual::before{
      content:"";
      position:absolute;
      inset:-40%;
      background:conic-gradient(from 180deg,rgba(216,178,92,.18),rgba(15,23,42,.08),rgba(216,178,92,.12));
      filter:blur(18px);
      opacity:.6;
      transform:rotate(8deg);
    }
    .hero-visual-inner{
      position:relative;
      z-index:1;
      height:100%;
      padding:2.3rem 2.3rem 2.4rem;
      display:flex;
      flex-direction:column;
      justify-content:space-between;
      gap:1.25rem;
    }
    .hero-visual-label{
      font-size:.76rem;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:rgba(15,23,42,.65);
    }
    .hero-visual-heading{
      margin-top:.65rem;
      font-size:1.55rem;
      font-weight:650;
      letter-spacing:-.04em;
      color:#0f172a;
      max-width:26rem;
      line-height:1.15;
    }
    .hero-visual-sub{
      margin-top:.55rem;
      font-size:.88rem;
      color:rgba(15,23,42,.62);
      max-width:30rem;
      line-height:1.5;
    }

    /* Wider centered mini-box */
    .hero-mini-wrap{
      display:flex;
      justify-content:center;
      width:100%;
      margin-top:1.05rem;
    }
    .hero-mini-box{
      width:min(680px, 96%);
      border-radius:22px;
      border:1px solid rgba(209,213,219,.75);
      background:rgba(255,255,255,.62);
      backdrop-filter:blur(14px);
      padding:1.05rem;
      box-shadow:0 18px 45px rgba(15,23,42,.08);
    }
    .hero-mini-grid{
      display:grid;
      grid-template-columns:repeat(3,minmax(0,1fr));
      gap:.85rem;
    }
    .mini-item{
      border-radius:16px;
      border:1px solid rgba(209,213,219,.75);
      background:rgba(255,255,255,.72);
      backdrop-filter:blur(12px);
      padding:.9rem .9rem;
      text-align:center;
    }
    .microcard-kicker{
      font-size:.66rem;
      letter-spacing:.16em;
      text-transform:uppercase;
      color:rgba(107,114,128,.95);
    }
    .microcard-value{
      margin-top:.38rem;
      font-size:1.02rem;
      font-weight:650;
      letter-spacing:-.03em;
      color:#111827;
    }
    .microcard-note{
      margin-top:.28rem;
      font-size:.76rem;
      color:rgba(107,114,128,.95);
      line-height:1.38;
    }

    /* SECTION SHELL */
    .section-heading{
      display:flex;
      justify-content:space-between;
      align-items:flex-end;
      gap:1.4rem;
      margin-bottom:2.3rem;
    }
    .section-title{
      font-size:1.55rem;
      font-weight:650;
      letter-spacing:-.04em;
      color:#111827;
    }
    .section-kicker{
      font-size:.74rem;
      letter-spacing:.2em;
      text-transform:uppercase;
      color:var(--accent);
      margin-bottom:.55rem;
    }
    .section-subtitle{
      font-size:.92rem;
      color:var(--text-muted);
      max-width:30rem;
      line-height:1.55;
    }

    /* ABOUT / WHY */
    .band-about{background:#fff;padding:5.3rem 0 5.7rem}
    .split-grid{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
      gap:2rem;
    }
    .panel{
      border-radius:22px;
      border:1px solid var(--border-subtle);
      background:#fff;
      padding:1.55rem 1.5rem;
      box-shadow:var(--shadow-soft);
      font-size:.86rem;
    }
    .panel h3{
      font-size:1.05rem;
      font-weight:650;
      margin-bottom:.6rem;
      color:#111827;
    }
    .panel p{color:var(--text-muted);margin-bottom:.85rem;line-height:1.55}
    .panel ul{list-style:none;padding-left:0;display:grid;gap:.55rem}
    .panel li{display:flex;gap:.55rem;color:var(--text-muted);line-height:1.45}
    .bullet{
      margin-top:.45rem;
      width:5px;height:5px;border-radius:999px;
      background:rgba(148,163,184,.9);
      flex-shrink:0;
    }

    /* Centered utility row (used for dropdown buttons) */
    .center-row{
      display:flex;
      justify-content:center;
      margin-top:1.35rem;
    }

    /* WHO dropdown */
    .who-body{
      margin-top:1.25rem;
      max-height:0;
      overflow:hidden;
      opacity:0;
      transform:translateY(10px);
      transition:max-height 520ms cubic-bezier(.22,1,.36,1),opacity 320ms ease-out,transform 360ms cubic-bezier(.22,1,.36,1);
      will-change:max-height,opacity,transform;
    }
    .who-body.open{
      max-height:2600px;
      opacity:1;
      transform:translateY(0);
    }

    /* Single card that wraps the photo + text */
    .who-card{
  margin-top:2.3rem;
      border-radius:22px;
      border:1px solid rgba(209,213,219,.75);
      background:rgba(255,255,255,.85);
      padding:1.35rem 1.25rem;
      box-shadow:0 18px 45px rgba(15,23,42,.06);
      position:relative;
    }
    .who-card::after{content:"";display:block;clear:both}

    .photo-placeholder{
      border-radius:22px;
      border:1px solid rgba(209,213,219,.75);
      background:linear-gradient(135deg, #f3f4f6, #e5e7eb);
      min-height:240px;
      box-shadow:0 18px 45px rgba(15,23,42,.06);
      position:relative;
      overflow:hidden;
    }
    .photo-placeholder::after{
      content:"Photo coming soon";
      position:absolute;
      left:16px;
      bottom:14px;
      font-size:.78rem;
      letter-spacing:.14em;
      text-transform:uppercase;
      color:rgba(15,23,42,.55);
      background:rgba(255,255,255,.65);
      border:1px solid rgba(209,213,219,.75);
      padding:.35rem .55rem;
      border-radius:999px;
      backdrop-filter:blur(10px);
    }

    /* Float the photo inside the card so the text fills the space to the right,
       then naturally drops underneath once it clears the photo height. */
    .who-photo{
      float:left;
      width:min(46%, 520px);
      margin:0 1.4rem 1.15rem 0;
    }

    
    .who-photo img{
      width:100%;
      height:auto;
      display:block;
      border-radius:22px;
      object-fit:cover;
      box-shadow:0 18px 45px rgba(15,23,42,.06);
    }
.who-text h3{
      font-size:1.05rem;
      font-weight:650;
      color:#111827;
      margin-bottom:.55rem;
      letter-spacing:-.01em;
    }

    .who-title{margin-top:0}

    .who-subhead{
      margin-top:1.15rem;
      margin-bottom:.45rem;
      font-size:.82rem;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:rgba(15,23,42,.72);
      font-weight:650;
    }
    .who-text p{
      color:var(--text-muted);
      line-height:1.6;
      font-size:.9rem;
      margin-bottom:.95rem;
    }
    .who-text p:last-child{margin-bottom:0}
    .who-text strong{color:#111827;font-weight:600}

    .who-points{
      list-style:none;
      display:grid;
      gap:.55rem;
      padding-left:0;
      margin-top:.35rem;
    }
    .who-points li{
      display:flex;
      gap:.55rem;
      color:var(--text-muted);
      line-height:1.45;
      font-size:.88rem;
    }

    /* SERVICES */
    .band-services{
      background:linear-gradient(180deg,var(--gold-50) 0,#fff 55%);
      padding:5.2rem 0 5.6rem;
    }
    .card-grid{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
      gap:1.7rem;
    }
    .card{
      border-radius:22px;
      border:1px solid var(--border-subtle);
      background:rgba(255,255,255,.9);
      padding:1.55rem 1.5rem;
      box-shadow:0 18px 40px rgba(15,23,42,.04);
      display:flex;
      flex-direction:column;
      gap:.9rem;
      position:relative;
      overflow:hidden;
      transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast);
    }
    .card::before{
      content:"";
      position:absolute;
      inset:-60%;
      background:radial-gradient(circle at top,rgba(216,178,92,.14),transparent 60%);
      opacity:0;
      transition:opacity var(--transition-fast);
      pointer-events:none;
    }
    .card:hover::before{opacity:1}
    .card:hover{
      transform:translateY(-5px);
      box-shadow:0 24px 60px rgba(15,23,42,.12);
      border-color:rgba(216,178,92,.9);
      background:#fff;
    }
    .card-tag{font-size:.74rem;color:var(--accent);text-transform:uppercase;letter-spacing:.18em}
    .card-title{font-size:1.05rem;font-weight:650}
    .card-body{font-size:.9rem;color:var(--text-muted);line-height:1.55}
    .card-footer{
      margin-top:.9rem;
      font-size:.76rem;
      color:rgba(255,255,255,.72);display:flex;
      align-items:center;
      justify-content:space-between;
      gap:.7rem;
    }
    .card-pills{display:flex;flex-wrap:wrap;gap:.45rem}
    .pill{
      font-size:.74rem;
      padding:.28rem .65rem;
      border-radius:999px;
      background:#f9fafb;
      border:1px solid rgba(209,213,219,.9);
    }

    /* PROCESS (dropdown section)
       Pull the section up into the Services bottom padding so the spacing
       between the button and dropdown content matches the "See who we are"
       dropdown.
    */
    .band-process{
      background:#fff;
      margin-top:-4.8rem;
      padding:0.8rem 0 5.7rem;
    }
    .process-body{
      max-height:0;
      overflow:hidden;
      opacity:0;
      transform:translateY(10px);
      transition:
        max-height 520ms cubic-bezier(.2,.8,.2,1),
        opacity 360ms ease,
        transform 360ms ease;
      margin-top:.9rem;
      will-change:max-height,opacity,transform;
    }
    .process-body.open{
      max-height:4000px;
      opacity:1;
      transform:translateY(0);
    }

/* Process header INSIDE dropdown */
    .process-intro{margin-bottom:1.05rem;}

    .process-highlight{
      border-radius:22px;
      border:1px solid rgba(216,178,92,.5);
      background:linear-gradient(135deg,#fff,var(--gold-100));
      padding:1.35rem 1.35rem;
      font-size:.9rem;
      box-shadow:var(--shadow-soft);
      line-height:1.55;
    }
    .process-highlight strong{color:var(--accent)}
    .process-highlight h3{
      font-size:1.02rem;
      font-weight:650;
      color:#111827;
      margin-bottom:.4rem;
      letter-spacing:-.02em;
    }
    .process-highlight p{color:rgba(15,23,42,.76)}
    .process-highlight p + p{margin-top:.65rem}

    /* Steps container */
    .process-steps{
      border-radius:22px;
      border:1px solid var(--border-subtle);
      background:#fff;
      padding:1.55rem 1.5rem;
      box-shadow:var(--shadow-soft);
      margin-top:1.2rem;
    }
    .process-step{
      display:grid;
      grid-template-columns:auto 1fr;
      gap:1rem;
      padding:.75rem .25rem;
    }
    .process-index{
      width:28px;height:28px;border-radius:999px;
      border:1px solid rgba(209,213,219,.9);
      display:flex;align-items:center;justify-content:center;
      font-size:.82rem;color:var(--text-muted);
      background:#f9fafb;
    }
    .process-content-title{font-size:.98rem;font-weight:650}
    .process-content-body{font-size:.88rem;color:var(--text-muted);margin-top:.18rem;line-height:1.55}

    /* PROJECTS */
    .band-projects{
      background:linear-gradient(180deg,#f3f4f6 0,#fff 80%);
      padding:5.2rem 0 5.6rem;
    }
    .projects-grid{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
      gap:1.7rem;
    }
    .project-card{
      border-radius:22px;
      border:1px solid var(--border-subtle);
      background:#fff;
      padding:1.35rem 1.25rem;
      display:flex;
      flex-direction:column;
      gap:.55rem;
      font-size:.86rem;
      position:relative;
      overflow:hidden;
      box-shadow:0 18px 45px rgba(15,23,42,.06);
      transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);
    }
    .project-card:hover{
      transform:translateY(-5px);
      box-shadow:0 24px 60px rgba(15,23,42,.14);
      border-color:rgba(216,178,92,.8);
    }
    .project-thumb{
      border-radius:18px;
      height:160px;
      margin-bottom:.65rem;
      background-size:cover;
      background-position:center;
      background-repeat:no-repeat;

      /* Subtle image grading for a premium, consistent look */
      position:relative;
      overflow:hidden;
      filter:saturate(1.03) contrast(1.03);
      transition:filter 220ms ease;
      transform:translateZ(0);
    }
    .project-thumb::after{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      /* soft vignette + top-to-bottom tint */
      background:
        radial-gradient(circle at 30% 20%, rgba(255,255,255,.10), transparent 55%),
        linear-gradient(180deg, rgba(15,23,42,.22) 0%, rgba(15,23,42,0) 46%, rgba(15,23,42,.14) 100%);
      opacity:.95;
      transition:opacity 220ms ease;
    }
    .project-card:hover .project-thumb{
      filter:saturate(1.08) contrast(1.05);
    }
    .project-card:hover .project-thumb::after{
      opacity:.85;
    }
    .project-thumb--1{background-image:linear-gradient(180deg,rgba(15,23,42,.18),rgba(15,23,42,.02)),url("../images/Example_Images/project-1.jpg"),linear-gradient(135deg,var(--gold-100),var(--gold-200))}
    .project-thumb--2{background-image:linear-gradient(180deg,rgba(15,23,42,.18),rgba(15,23,42,.02)),url("../images/Example_Images/project-2.jpg"),linear-gradient(135deg,#e5e7eb,#cbd5f5)}
    .project-thumb--3{background-image:linear-gradient(180deg,rgba(15,23,42,.18),rgba(15,23,42,.02)),url("../images/Example_Images/project-3.jpg"),linear-gradient(135deg,#fef3c7,var(--gold-200))}
    
    .project-thumb--4{background-image:url("../images/Example_Images/project-4.jpg");}
.project-tag{font-size:.74rem;color:var(--accent);text-transform:uppercase;letter-spacing:.16em}
    .project-title{font-size:1rem;font-weight:650;line-height:1.3}
    .project-meta{font-size:.88rem;color:var(--text-muted);line-height:1.55}
    .project-badge{
      margin-top:.6rem;
      align-self:flex-start;
      font-size:.74rem;
      padding:.32rem .7rem;
      border-radius:999px;
      background:var(--gold-50);
      border:1px solid rgba(216,178,92,.7);
      color:var(--accent);
    }

    /* CONTACT */
    .band-contact{
      background:radial-gradient(circle at top,var(--gold-100) 0,#fff 60%);
      padding:5.2rem 0 6rem;
    }
    .cta{
      border-radius:24px;
      border:1px solid rgba(216,178,92,.6);
      background:linear-gradient(135deg,#fff,var(--gold-100));
      padding:2rem 1.9rem;
      box-shadow:var(--shadow-soft);
      display:grid;
      grid-template-columns:1.4fr 1fr;
      gap:2rem;
      align-items:center;
    }
    .cta-title{
      font-size:1.3rem;
      font-weight:650;
      margin-bottom:.55rem;
      color:#111827;
      line-height:1.2;
    }
    .cta-text{
      font-size:.95rem;
      color:var(--text-muted);
      max-width:30rem;
      line-height:1.55;
    }
    .cta-note{margin-top:.9rem;font-size:.82rem;color:var(--text-muted);line-height:1.5}

    form{display:grid;gap:.85rem}
    .field-group{display:grid;gap:.38rem}
    label{font-size:.78rem;color:var(--text-muted)}
    input,select,textarea{
      font-family:inherit;
      font-size:.88rem;
      border-radius:999px;
      border:1px solid rgba(209,213,219,.9);
      background:#fff;
      padding:.65rem .9rem;
      color:var(--text-main);
      outline:none;
      transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);
    }
    textarea{
      border-radius:16px;
      min-height:110px;
      resize:vertical;
      padding-top:.7rem;
    }
    input:focus,select:focus,textarea:focus{
      border-color:var(--accent);
      box-shadow:0 0 0 1px rgba(216,178,92,.6);
      background:#fff;
    }
    .form-helper{font-size:.76rem;color:var(--text-muted)}
    .form-success{
      display:none;
      margin-top:.7rem;
      font-size:.82rem;
      color:#0f172a;
      padding:.75rem .9rem;
      border-radius:14px;
      background:rgba(255,255,255,.8);
      border:1px solid rgba(209,213,219,.9);
    }
    .form-success.show{display:block}

    /* FOOTER */
    footer{
      border-top:1px solid rgba(216,178,92,.22);padding:3.2rem 0 2.8rem;
      font-size:.82rem;
      color:rgba(255,255,255,.72);background:var(--brand-blue);}
    .footer-inner{
      max-width:var(--max-width);
      margin:0 auto;
      padding:0 1.25rem;
      display:flex;
      flex-wrap:wrap;
      gap:1rem;
      justify-content:space-between;
      align-items:center;
    }
    .footer-links{display:flex;flex-wrap:wrap;gap:1rem}
    .footer-links a{
      color:rgba(255,255,255,.72);
      text-decoration:none;
      font-size:.8rem;
    }
    .footer-links a:hover{color:var(--brand-gold)}

    /* Mobile nav (slide-down) */
    @media (max-width: 768px){
      .nav-toggle{display:block}
      nav{
        position:fixed;
        left:0;right:0;
        top:var(--header-h);
        z-index:60;
        display:grid;
        gap:.85rem;
        padding:1rem 1.1rem 1.2rem;
        background:rgba(24,45,58,.96);
        border-bottom:1px solid rgba(209,213,219,.8);
        backdrop-filter:blur(18px);
        transform:translateY(-16px);
        opacity:0;
        pointer-events:none;
        transition:transform 240ms ease,opacity 240ms ease;
      }
      nav.open{
        transform:translateY(0);
        opacity:1;
        pointer-events:auto;
      }
      .nav-links{
        flex-direction:column;
        align-items:flex-start;
        gap:.85rem;
      }
      nav a{font-size:1rem;padding:.25rem 0}
      .nav-cta{
        width:100%;
        justify-content:center;
        padding:.85rem 1rem;
      }
      .section-heading{flex-direction:column;align-items:flex-start}
      .cta{padding:1.55rem 1.35rem}
      .band-inner{padding-inline:1rem}
      .brand{gap:.5rem;min-width:unset}
      .brand-name{font-size:.82rem}
      .brand-tagline{font-size:.6rem}
      .who-photo{
        float:none;
        width:100%;
        margin:0 0 1rem 0;}
    }

    /* RESPONSIVE */
    @media (max-width: 960px){
      .hero-inner{grid-template-columns:minmax(0,1fr)}
      .hero-right{gap:1.25rem}
      .card-grid,.projects-grid{grid-template-columns:minmax(0,1fr)}
      .split-grid,.cta{grid-template-columns:minmax(0,1fr)}
      .hero-visual{min-height:380px}
      .hero-band{padding-top:4.4rem;padding-bottom:4.6rem}
      .hero-mini-grid{grid-template-columns:1fr}
      .hero-mini-box{width:min(640px, 94%)}
    }

    /* Respect reduced motion */
    @media (prefers-reduced-motion: reduce){
      *{transition:none !important;scroll-behavior:auto !important}
      .hero-band::after{display:none !important}
    }
  
    .emphasis-quote{
      font-style: italic;
      color: var(--text-muted);
      margin-top: 1.1rem;
      max-width: 42rem;
    }


  
/* --- WHO WE ARE card: match Contracting highlight --- */
.who-highlight{
  border-radius:22px;
  border: 1px solid rgba(216,178,92, .35);
  background:linear-gradient(135deg,var(--gold-50),#fff);
  box-shadow:0 18px 45px rgba(15,23,42,.06);
}


  /* Enquiry modal helpers */
  .ca-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  @media (max-width:520px){.ca-grid2{grid-template-columns:1fr}}
  .ca-smalllabel{display:block;font-size:.82rem;color:var(--muted);margin:0 0 6px}
  .ca-textarea{width:100%;border-radius:14px;border:1px solid rgba(148,163,184,.55);background:rgba(255,255,255,.75);padding:12px 12px;font-size:.95rem;line-height:1.5;resize:vertical;min-height:120px}
  .ca-textarea:focus{outline:2px solid rgba(216,178,92,.25);border-color:rgba(216,178,92,.45)}
  .ca-check{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--text)}
  .ca-check input{margin-top:3px}

  .ca-result-ok,.ca-result-no{
    margin-top: 14px;
    padding: 14px 14px;
    border-radius: 18px;
    border: 1px solid rgba(209,213,219,.85);
    background: rgba(255,255,255,.78);
    box-shadow: 0 18px 45px rgba(15,23,42,.06);
  }
  .ca-result-ok{ border-color: rgba(34,197,94,.35); background: rgba(240,253,244,.8); }
  .ca-result-no{ border-color: rgba(216,178,92,.4); background: rgba(254,242,242,.85); }

  .ca-badge{
    font-size:.78rem;
    font-weight:700;
    padding:.28rem .55rem;
    border-radius:999px;
    border:1px solid rgba(148,163,184,.55);
    background: rgba(255,255,255,.7);
    color: rgba(15,23,42,.78);
    white-space:nowrap;
  }
  .ca-badge.ok{ border-color: rgba(34,197,94,.35); color: rgba(22,101,52,.92); background: rgba(220,252,231,.65); }
  .ca-badge.no{ border-color: rgba(216,178,92,.45); color: rgba(153,27,27,.9); background: rgba(254,226,226,.7); }

/* Legal */
.band-legal{padding-top: 40px}
.legal-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
@media (max-width: 820px){.legal-grid{grid-template-columns:1fr}}
.legal-card{border-radius:18px;border:1px solid rgba(209,213,219,.85);background:rgba(255,255,255,.72);padding:18px;box-shadow: var(--shadow-soft)}
.legal-title{margin:0 0 8px;font-size:1.02rem}
.legal-text{margin:0 0 10px;color:var(--muted);line-height:1.6}


/* --- Cookie banner (bottom) --- */
.ca-cookie-banner{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:12000;
  background:rgba(24,45,58,.96);
  backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-top:1px solid var(--border-subtle);
  box-shadow:0 -18px 50px rgba(15,23,42,.10);
}
.ca-cookie-inner{
  max-width:var(--max-width);
  margin:0 auto;
  padding:14px 18px;
  display:flex;
  gap:14px;
  align-items:center;
  justify-content:space-between;
}
.ca-cookie-text{
  color: rgba(255,255,255,.75);
  font-size:14px;
}
.ca-cookie-text a{
  color: var(--brand-gold);
  text-decoration:none;
  border-bottom:1px solid rgba(216,178,92,.55);
  font-weight:500;
}
.ca-cookie-text a:hover{
  color:#f2cc75;
  border-bottom-color:#f2cc75;
}
.ca-cookie-text a:hover{ border-bottom-color: rgba(216,178,92,.55); }
.ca-cookie-actions{
  display:flex;
  gap:10px;
  flex:0 0 auto;
}
.ca-cookie-btn{
  border-radius:999px;
  padding:10px 14px;
  font-weight:600;
  font-size:13px;
  cursor:pointer;
  transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}
.ca-cookie-accept{
  background:var(--accent-strong);
  color:#fff;
  border:1px solid rgba(216,178,92,.35);
  box-shadow:0 14px 30px rgba(216,178,92,.18);
}
.ca-cookie-accept:hover{ transform:translateY(-1px); box-shadow:0 18px 42px rgba(216,178,92,.22); }
.ca-cookie-dismiss{
  background:#fff;
  color:var(--text-main);
  border:1px solid var(--border-subtle);
}
.ca-cookie-dismiss:hover{ transform:translateY(-1px); box-shadow:0 16px 40px rgba(15,23,42,.10); }

@media (max-width: 720px){
  .ca-cookie-inner{
    flex-direction:column;
    align-items:flex-start;
  }
  .ca-cookie-actions{ width:100%; }
  .ca-cookie-btn{ width:100%; text-align:center; }
}


/* Coverage outcome message (Step 1) */
.ca-coverage-outcome{
  margin-top:12px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.7);
  color: var(--text-main);
  font-size: 14px;
}
.ca-coverage-outcome.ca-ok{
  border-color: rgba(30,111,67,.25);
}
.ca-coverage-outcome.ca-no{
  border-color: rgba(154,31,31,.25);
}
.ca-coverage-outcome .ca-pill{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  margin-right:10px;
  border:1px solid rgba(0,0,0,.10);
}
.ca-coverage-outcome.ca-ok .ca-pill{
  background: rgba(30,111,67,.10);
  color: #1e6f43;
  border-color: rgba(30,111,67,.25);
}
.ca-coverage-outcome.ca-no .ca-pill{
  background: rgba(154,31,31,.10);
  color: #9a1f1f;
  border-color: rgba(154,31,31,.25);
}

/* Active state for segmented chips (preferred contact) */
.ca-chip.active{
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}

/* Required marker */
.ca-required{ color:#b91c1c; margin-left:2px; font-weight:650; }

/* Contact section refinements (layout + enquiry panel) */
.band-contact .cta{
  align-items: flex-start;
}
.band-contact .enquiry-panel{
  margin-top: 34px;              /* drops the right-hand block to align with left body copy */
  display: flex;
  flex-direction: column;
  align-items: center;           /* centers the button within the right column */
  text-align: center;
  gap: 14px;
}
.band-contact .enquiry-panel .enquiry-note{
  margin: 0;
}


/* --- Who we are image enhancement --- */
.who-photo-inner{
  position:relative;
  border-radius:22px;
  overflow:hidden;
}
.who-photo-inner img{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  filter:brightness(1.06) contrast(1.02);
  transition:transform .45s ease, filter .45s ease;
}
.who-photo-inner:hover img{
  transform:scale(1.03);
  filter:brightness(1.14) contrast(1.04);
}
.who-linkedin{
  position:absolute;
  right:14px;
  bottom:14px;
  width:38px;
  height:38px;
  border-radius:50%;
  background:rgba(15,23,42,.85);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 14px 34px rgba(15,23,42,.35);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.who-linkedin svg{
  width:18px;
  height:18px;
  fill:#ffffff;
}
.who-linkedin:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 45px rgba(15,23,42,.45);
  background:rgba(15,23,42,.95);
}


/* --- How we work CTA buttons (ghost variant) --- */
.work-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 18px;
  border-radius:999px;
  background:transparent;
  border:1px solid rgba(15,23,42,.22);
  color: rgba(15,23,42,.82);
  font-weight:600;
  transition: all .22s ease;
}
.work-cta:hover{
  border-color: rgba(216,178,92,.55);
  color: #182D3A;
  background: rgba(216,178,92,.08);
  box-shadow: 0 10px 26px rgba(15,23,42,.10);
  transform: translateY(-1px);
}

<!-- Coverage Checker (button + modal) -->

  /* Uses existing site variables: --text-main, --text-muted, --accent-strong, --shadow-soft, --shadow-strong */

  .ca-coverage-btn{
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 9998;

    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 16px;
    border-radius: 999px;
    border: 1px solid rgba(209,213,219,.9);
    background: rgba(255,255,255,.86);
    color: var(--text-main);
    font-weight: 600;
    font-size: .88rem;
    cursor: pointer;
    text-decoration: none;

    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: var(--shadow-soft);
    transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
  }
  .ca-coverage-btn::before{
    content:"";
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: radial-gradient(circle at 30% 30%, #fff 0%, rgba(255,255,255,.4) 30%, transparent 60%),
                linear-gradient(120deg,var(--accent-strong),#D8B25C);
    box-shadow: 0 10px 28px rgba(216,178,92,.35);
  }
  .ca-coverage-btn:hover{
    background: rgba(249,250,251,.92);
    border-color: rgba(148,163,184,.9);
    transform: translateY(-1px);
    box-shadow: var(--shadow-strong);
  }

  .ca-modal{
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(15,23,42,.55);
  }
  .ca-modal[aria-hidden="false"]{ display: flex; }

  .ca-modal-card{
    width: min(820px, 100%);
    border-radius: 22px;
    border: 1px solid rgba(209,213,219,.75);
    overflow: hidden;
    box-shadow: var(--shadow-strong);
    background:
      radial-gradient(circle at 20% 15%,rgba(255,255,255,.85) 0,transparent 55%),
      radial-gradient(circle at 80% 70%,rgba(216,178,92,.18) 0,transparent 55%),
      linear-gradient(135deg,#fff 0%,#f5f5f7 55%,var(--gold-50) 100%);
  }

  .ca-modal-head{
    padding: 16px 18px;
    display:flex;
    align-items:flex-start;
    justify-content: space-between;
    gap: 14px;
    border-bottom: 1px solid rgba(209,213,219,.75);
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  .ca-modal-title{
    font-size: 1.02rem;
    font-weight: 650;
    margin:0;
    color: var(--text-main);
    letter-spacing: -.01em;
  }
  .ca-modal-sub{
    margin-top: 4px;
    font-size: .86rem;
    color: var(--text-muted);
    line-height: 1.4;
  }

  .ca-modal-close{
    border: 1px solid rgba(209,213,219,.9);
    background: rgba(255,255,255,.75);
    color: var(--text-main);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    padding: 8px 10px;
    border-radius: 12px;
    transition: background var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);
  }
  .ca-modal-close:hover{
    background: rgba(249,250,251,.92);
    border-color: rgba(148,163,184,.9);
    transform: translateY(-1px);
  }

  .ca-modal-body{ padding: 16px 18px 18px; }

  .ca-row{ display:grid; gap: 10px; margin-bottom: 14px; }

  .ca-label{
    font-size: .86rem;
    color: var(--text-muted);
  }

  .ca-input{
    width: 100%;
    padding: 12px 12px;
    border-radius: 14px;
    border: 1px solid rgba(209,213,219,.9);
    font-size: 1rem;
    outline: none;
    background: rgba(255,255,255,.92);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  }
  .ca-input:focus{
    border-color: rgba(216,178,92,.55);
    box-shadow: 0 0 0 5px rgba(216,178,92,.14);
    background: #fff;
  }

  /* Segmented service choice */
  .ca-seg{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .ca-chip{
    border: 1px solid rgba(209,213,219,.9);
    background: rgba(255,255,255,.85);
    padding: 12px 12px;
    border-radius: 999px;
    cursor:pointer;
    font-size: .92rem;
    font-weight: 600;
    color: var(--text-main);
    text-align: center;
    transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .ca-chip:hover{
    background: rgba(249,250,251,.92);
    border-color: rgba(148,163,184,.9);
    transform: translateY(-1px);
    box-shadow: 0 12px 30px rgba(15,23,42,.08);
  }
  .ca-chip[aria-pressed="true"]{
    background: linear-gradient(120deg, rgba(216,178,92,.16), rgba(249,115,115,.08));
    border-color: rgba(216,178,92,.45);
    box-shadow: 0 18px 45px rgba(216,178,92,.18);
  }

  .ca-actions{
  display:flex;
  justify-content:center;
  gap:16px;
  margin-top:28px;
}

  /* Match existing site buttons */
  .ca-primary{border:none;
    border-radius:999px;
    padding: .9rem 1.25rem;
    cursor:pointer;
    font-size: .9rem;
    font-weight: 650;
    background:var(--brand-blue);
    color:var(--gold-50);
    box-shadow: 0 18px 50px rgba(24,45,58,.28);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);
  }
  .ca-primary:hover{
    transform: translateY(-2px);
    box-shadow: 0 26px 70px rgba(24,45,58,.38);
    filter: brightness(1.03);
  }

  .ca-secondary{
    border: 1px solid rgba(209,213,219,.9);
    border-radius: 999px;
    padding: .9rem 1.2rem;
    cursor: pointer;
    font-size: .88rem;
    font-weight: 600;
    background: rgba(255,255,255,.85);
    color: var(--text-main);
    transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .ca-secondary:hover{
    background: rgba(249,250,251,.92);
    border-color: rgba(148,163,184,.9);
    transform: translateY(-1px);
    box-shadow: 0 12px 30px rgba(15,23,42,.08);
  }

  .ca-result{
    margin-top: 14px;
    padding: 14px 14px;
    border-radius: 18px;
    border: 1px solid rgba(209,213,219,.85);
    background: rgba(255,255,255,.78);
    display:none;
    box-shadow: 0 18px 45px rgba(15,23,42,.06);
  }
  .ca-result.show{ display:block; }

  .ca-pill{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
    border: 1px solid rgba(209,213,219,.85);
    background: rgba(255,255,255,.85);
    margin-right: 10px;
  }
  .ca-pill::before{
    content:"";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(148,163,184,.9);
  }
  .ca-pill--ok{
    border-color: rgba(34,197,94,.35);
    background: rgba(34,197,94,.08);
  }
  .ca-pill--ok::before{ background: rgba(34,197,94,.9); }
  .ca-pill--bad{
    border-color: rgba(216,178,92,.35);
    background: rgba(216,178,92,.10);
  }
  .ca-pill--bad::before{ background: rgba(216,178,92,.9); }

  .ca-result strong{ font-weight: 750; color: var(--text-main); }
  .ca-mini{ font-size: .9rem; color: var(--text-muted); margin-top: 8px; line-height: 1.5; }

  .ca-cta{
    margin-top: 12px;
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
  }
  .ca-cta a{ text-decoration: none; display:inline-block; }

  @media (max-width: 520px){
    .ca-modal-card{ border-radius: 18px; }
    .ca-seg{ grid-template-columns: 1fr; }
    .ca-actions{
  display:flex;
  justify-content:center;
  gap:16px;
  margin-top:28px;
}
    .ca-actions button{ width: 100%; }
  }


.ca-privacy-content p{ margin:0 0 14px 0; }
.ca-privacy-content ul{ margin:0 0 18px 18px; padding:0; }
.ca-privacy-content li{ margin-bottom:8px; }

#caPrivacyModal .ca-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}

/* Coverage outcome message (Step 1) */
.ca-coverage-outcome{
  margin-top:12px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.7);
  color: var(--text-main);
  font-size: 14px;
}
.ca-coverage-outcome.ca-ok{
  border-color: rgba(30,111,67,.25);
}
.ca-coverage-outcome.ca-no{
  border-color: rgba(154,31,31,.25);
}
.ca-coverage-outcome .ca-pill{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  margin-right:10px;
  border:1px solid rgba(0,0,0,.10);
}
.ca-coverage-outcome.ca-ok .ca-pill{
  background: rgba(30,111,67,.10);
  color: #1e6f43;
  border-color: rgba(30,111,67,.25);
}
.ca-coverage-outcome.ca-no .ca-pill{
  background: rgba(154,31,31,.10);
  color: #9a1f1f;
  border-color: rgba(154,31,31,.25);
}

/* Active state for segmented chips (preferred contact) */
.ca-chip.active{
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}

/* Required marker */
.ca-required{ color:#b91c1c; margin-left:2px; font-weight:650; }

/* --- Who we are image enhancement --- */
.who-photo-inner{
  position:relative;
  border-radius:22px;
  overflow:hidden;
}
.who-photo-inner img{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  filter:brightness(1.06) contrast(1.02);
  transition:transform .45s ease, filter .45s ease;
}
.who-photo-inner:hover img{
  transform:scale(1.03);
  filter:brightness(1.14) contrast(1.04);
}
.who-linkedin{
  position:absolute;
  right:14px;
  bottom:14px;
  width:38px;
  height:38px;
  border-radius:50%;
  background:rgba(15,23,42,.85);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 14px 34px rgba(15,23,42,.35);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.who-linkedin svg{
  width:18px;
  height:18px;
  fill:#ffffff;
}
.who-linkedin:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 45px rgba(15,23,42,.45);
  background:rgba(15,23,42,.95);
}


/* --- How we work CTA buttons (ghost variant) --- */
.work-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 18px;
  border-radius:999px;
  background:transparent;
  border:1px solid rgba(15,23,42,.22);
  color: rgba(15,23,42,.82);
  font-weight:600;
  transition: all .22s ease;
}
.work-cta:hover{
  border-color: rgba(216,178,92,.55);
  color: #182D3A;
  background: rgba(216,178,92,.08);
  box-shadow: 0 10px 26px rgba(15,23,42,.10);
  transform: translateY(-1px);
}



/* ===== CLEAN HERO BUILD ===== */

.hero-band{
  position:relative;
  overflow:hidden;
  background:#ffffff;
  padding:7rem 0 6rem;
  border-bottom:1px solid rgba(24,45,58,.08);
  box-shadow:0 40px 80px rgba(24,45,58,.06);
  opacity:0;
  transform:translateY(18px);
  animation:heroReveal 1.2s cubic-bezier(.22,.61,.36,1) forwards;
}

.hero-glow{
  position:absolute;
  top:-25%;
  left:-15%;
  width:130%;
  height:130%;
  background:radial-gradient(circle at 40% 35%,
    rgba(216,178,92,.24),
    rgba(216,178,92,.12) 40%,
    transparent 70%);
  filter:blur(85px);
  animation:goldFloat 18s ease-in-out infinite;
  pointer-events:none;
  z-index:0;
}

.hero-band .band-inner{
  position:relative;
  z-index:1;
}

.hero-visual{
  background:#ffffff;
  border:1px solid rgba(24,45,58,.08);
  box-shadow:0 30px 80px rgba(24,45,58,.10);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.hero-visual:hover{
  transform:translateY(-4px);
  box-shadow:0 40px 100px rgba(24,45,58,.18);
  border-color:rgba(216,178,92,.6);
}

@keyframes heroReveal{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes goldFloat{
  0%   { transform:translate3d(-3%, -2%, 0) scale(1); }
  50%  { transform:translate3d(3%, 2%, 0) scale(1.05); }
  100% { transform:translate3d(-3%, -2%, 0) scale(1); }
}




/* ===== Improve Service Pill Visibility ===== */

.service-card .pill,
.band .pill,
.card .pill{
    background: rgba(24,45,58,0.06);
    border: 1px solid rgba(24,45,58,0.18);
    color: #182D3A;
    font-weight: 500;
}

.service-card .pill:hover,
.band .pill:hover,
.card .pill:hover{
    background: rgba(216,178,92,0.18);
    border-color: rgba(216,178,92,0.6);
    color: #182D3A;
}




/* ===== Toggle Refinement ===== */

.ca-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  transition:color .25s ease;
}

.ca-toggle .ca-chevron{
  transition:transform .25s ease;
}

.ca-toggle.active{
  color:var(--brand-gold);
}

.ca-toggle.active .ca-chevron{
  transform:rotate(180deg);
}

.ca-dropdown{
  overflow:hidden;
  transition:max-height .4s ease;
  max-height:0;
}




/* ===== Dropdown button affordance (Who we are / How we work) ===== */
#who-toggle, #process-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

#who-toggle .ca-chevron, #process-toggle .ca-chevron{
  display:inline-block;
  transition: transform .22s ease, color .22s ease;
  transform: translateY(1px);
}

/* Visual cue when open */
#who-toggle[aria-expanded="true"],
#process-toggle[aria-expanded="true"]{
  color: var(--brand-gold);
  border-color: rgba(216,178,92,.55);
  background: rgba(216,178,92,.10);
}

#who-toggle[aria-expanded="true"] .ca-chevron,
#process-toggle[aria-expanded="true"] .ca-chevron{
  transform: rotate(180deg) translateY(-1px);
  color: var(--brand-gold);
}

/* Slight hover affordance */
#who-toggle:hover, #process-toggle:hover{
  border-color: rgba(216,178,92,.45);
}




/* ===== FINAL VISUAL CONSISTENCY POLISH ===== */

/* Standard radius */
.hero-visual,
.service-card,
.ca-dropdown,
button,
.ca-btn{
  border-radius:22px !important;
}

/* Unified shadow */
.hero-visual,
.service-card,
.ca-dropdown{
  box-shadow:0 30px 80px rgba(24,45,58,.10) !important;
  transition:all .25s cubic-bezier(.22,.61,.36,1);
}

.hero-visual:hover,
.service-card:hover{
  box-shadow:0 40px 100px rgba(24,45,58,.18) !important;
  transform:translateY(-3px);
}

/* Button consistency */
button,
.ca-btn{
  transition:all .25s cubic-bezier(.22,.61,.36,1);
}

button:hover,
.ca-btn:hover{
  transform:translateY(-2px);
}

/* Section rhythm increase (handled per-band to preserve layout) */
/* Typography polish */
body{
  line-height:1.65;
}

.hero-title{
  letter-spacing:-0.045em;
}

/* Dropdown timing refinement */
.ca-dropdown{
  transition:max-height .45s cubic-bezier(.22,.61,.36,1);
}

/* Gold consistency */
:root{
  --brand-gold:#D8B25C;
}

/* Cookie button alignment */
.ca-cookie-buttons button{
  border-radius:22px;
  transition:all .25s cubic-bezier(.22,.61,.36,1);
}

.ca-cookie-buttons button:hover{
  transform:translateY(-2px);
}


.ca-privacy-content{
  padding:32px 40px;
  overflow-y:auto;
  flex:1;
  line-height:1.65;
  font-size:14px;
  color:var(--text-muted);
}

.ca-privacy-content::-webkit-scrollbar{
  width:8px;
}
.ca-privacy-content::-webkit-scrollbar-thumb{
  background:rgba(24,45,58,.25);
  border-radius:999px;
}
.ca-privacy-content::-webkit-scrollbar-thumb:hover{
  background:rgba(24,45,58,.45);
}

.ca-privacy-content h3{
  margin:24px 0 10px;
  font-size:1rem;
  font-weight:650;
  color:var(--text-main);
}

.ca-privacy-content p{
  margin:0 0 14px 0;
}

.ca-privacy-content ul{
  margin:0 0 18px 20px;
}

.ca-privacy-content li{
  margin-bottom:8px;
}


/* =========================================================
   PRIVACY MODAL – FINAL (Scoped + Scrollable)
========================================================= */

#caPrivacyModal .ca-modal-card{
  max-height:90vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

#caPrivacyModal .ca-privacy-content{
  padding:32px 40px;
  overflow-y:auto;
  flex:1;
  line-height:1.65;
  font-size:14px;
  color:var(--text-muted);
}

#caPrivacyModal .ca-privacy-content h3{
  margin:24px 0 10px;
  font-size:1rem;
  font-weight:650;
  color:var(--text-main);
}

#caPrivacyModal .ca-privacy-content p{
  margin:0 0 14px 0;
}

#caPrivacyModal .ca-privacy-content ul{
  margin:0 0 18px 20px;
}

#caPrivacyModal .ca-privacy-content li{
  margin-bottom:8px;
}

#caPrivacyModal .ca-privacy-content::-webkit-scrollbar{
  width:8px;
}
#caPrivacyModal .ca-privacy-content::-webkit-scrollbar-thumb{
  background:rgba(24,45,58,.25);
  border-radius:999px;
}
#caPrivacyModal .ca-privacy-content::-webkit-scrollbar-thumb:hover{
  background:rgba(24,45,58,.45);
}


/* =========================================================
   PRIVACY MODAL – SCROLL FORCE PATCH (Flex min-height fix)
   Ensures scroll works even if other modal rules override.
========================================================= */

#caPrivacyModal{
  align-items:center;
  justify-content:center;
}

#caPrivacyModal .ca-modal-card,
#caPrivacyModal .ca-privacy-card,
.ca-modal #caPrivacyModal .ca-modal-card{
  max-height:90vh !important;
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
  min-height:0 !important; /* critical for flex overflow */
}

#caPrivacyModal .ca-privacy-content{
  overflow-y:auto !important;
  flex:1 1 auto !important;
  min-height:0 !important; /* critical for flex overflow */
  -webkit-overflow-scrolling:touch;
}

/* Keep actions visible */
#caPrivacyModal .ca-actions{
  flex:0 0 auto;
}

/* ==============================================
   FORCE CLEAN SINGLE-PILL TOGGLES
   (removes outer container look completely)
============================================== */

/* Remove outer wrapper visual box */
.toggle-wrapper,
.ca-toggle-wrapper,
.work-cta-wrapper,
.toggle-section-wrapper {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* Remove any extra container styling around the buttons */
.toggle-wrapper *,
.ca-toggle-wrapper *,
.work-cta-wrapper * {
  box-shadow: none !important;
}

/* Make the actual toggle button the single pill */
#who-toggle,
#process-toggle {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;

  padding: 12px 26px !important;
  border-radius: 999px !important;

  border: 1px solid rgba(24,45,58,.18) !important;
  background: rgba(255,255,255,.95) !important;

  font-weight: 600;
  font-size: .92rem;
  color: #182D3A;

  cursor: pointer;
  transition: all .25s cubic-bezier(.22,.61,.36,1);
  box-shadow: 0 8px 20px rgba(24,45,58,.06) !important;
}

/* Hover state */
#who-toggle:hover,
#process-toggle:hover {
  border-color: rgba(216,178,92,.6) !important;
  background: rgba(216,178,92,.08) !important;
  box-shadow: 0 14px 35px rgba(24,45,58,.10) !important;
  transform: translateY(-1px);
}

/* Active (expanded) state */
#who-toggle[aria-expanded="true"],
#process-toggle[aria-expanded="true"] {
  background: rgba(216,178,92,.14) !important;
  border-color: rgba(216,178,92,.65) !important;
  box-shadow: 0 18px 45px rgba(216,178,92,.18) !important;
}

/* Chevron animation */
#who-toggle .ca-chevron,
#process-toggle .ca-chevron {
  transition: transform .25s ease;
}

#who-toggle[aria-expanded="true"] .ca-chevron,
#process-toggle[aria-expanded="true"] .ca-chevron {
  transform: rotate(180deg);
}