:root{
    /* Brand */
    --plum:#481858;
    --plum-d:#3A1247;
    --lav:#9880A8;
    --wash:#F8E0F8;
    --wash-2:#FBF8FC;
    --ink:#202128;
    --white:#FFFFFF;
    /* Neutrals (derived from brand) */
    --muted:rgba(32,33,40,.68);
    --line:rgba(72,24,88,.14);
    --line-strong:rgba(72,24,88,.24);
    --card:#FFFFFF;
    --header-bg:rgba(255,255,255,.86);
    /* Type scale (large, per spec) */
    --h1:clamp(2.6rem,6.2vw,72px);
    --h2:clamp(1.9rem,4.2vw,48px);
    --h3:24px;
    --body:18px;
    --small:14px;
    --nav:15px;
    /* Spacing scale */
    --s2:2px;--s4:4px;--s8:8px;--s12:12px;--s16:16px;--s20:20px;--s24:24px;
    --s32:32px;--s40:40px;--s48:48px;--s56:56px;--s64:64px;--s80:80px;--s96:96px;--s120:120px;--s144:144px;
    /* Layout */
    --maxw:1440px;
    --pad:clamp(24px,4vw,64px);
    --header-height:80px;
    /* Radius */
    --r-sm:10px;--r-md:16px;--r-lg:24px;--r-xl:32px;--r-pill:999px;
    /* Shadows (light, techy/flat) */
    --shadow-soft:0 8px 28px rgba(72,24,88,.06);
    --shadow-card:0 4px 16px rgba(32,33,40,.04);
    /* Breakpoints reference: sm 640 · md 768 · stack 980 · lg 1200 */
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:'Inter','Helvetica Neue',Arial,sans-serif;color:var(--ink);line-height:1.65;font-size:var(--body);background:var(--white);-webkit-font-smoothing:antialiased}
  h1,h2,h3{letter-spacing:-0.025em;color:var(--ink);font-weight:800}
  h1{font-size:var(--h1);line-height:.98;font-weight:800}
  h2{font-size:var(--h2);line-height:1.04;font-weight:800}
  h3{font-size:var(--h3);line-height:1.2;font-weight:700}
  p{color:var(--muted)}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
  .eyebrow{font-size:var(--small);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--lav)}
  a{text-decoration:none;color:inherit}

  /* buttons */
  .btn{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;padding:13px 26px;border-radius:10px;cursor:pointer;border:1.5px solid transparent;transition:.18s;white-space:nowrap}
  .btn-p{background:var(--plum);color:var(--white)}
  .btn-p:hover{background:var(--plum-d)}
  .btn-g{background:transparent;color:var(--plum);border-color:var(--plum)}
  .btn-g:hover{background:var(--wash)}
  .btn-w{background:var(--white);color:var(--plum)}
  .btn-w:hover{background:var(--wash)}
  .btn-ghost-w{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
  .btn-ghost-w:hover{background:rgba(255,255,255,.12)}

  /* header */
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:74px}
  .brand{display:flex;align-items:center}
  .brand img{height:34px;width:auto;display:block}
  .nav-links{display:flex;gap:30px;font-size:.95rem;font-weight:500;color:#4A4750}
  .nav-links a:hover{color:var(--plum)}
  .nav-links a.active{color:var(--plum);font-weight:600}
  .nav-cta{display:flex;gap:12px;align-items:center}
  .nav-cta .btn{padding:10px 20px;font-size:.9rem}
  .hamburger{display:none;font-size:1.6rem;color:var(--plum);background:none;border:none;cursor:pointer}

  /* variant label */
  .vlabel{max-width:var(--maxw);margin:32px auto 0;padding:0 28px}
  .vlabel span{display:inline-block;background:var(--ink);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:6px}

  /* HERO A — full bleed */
  .heroA{position:relative;height:calc(100svh - var(--header-height));min-height:400px;max-height:600px;display:flex;align-items:center;overflow:hidden}
  .heroA .bg{position:absolute;inset:0;background-size:cover;background-position:right center}
  .heroA .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(58,18,71,.94) 0%,rgba(58,18,71,.82) 30%,rgba(72,24,88,.45) 52%,rgba(72,24,88,.05) 72%,rgba(72,24,88,0) 100%)}
  .hero-full{width:100%}
  .heroA .inner{position:relative;z-index:2;padding:32px clamp(24px,5vw,80px);max-width:620px}
  .heroA h1{color:#fff;font-size:clamp(2.2rem,4.6vw,56px);line-height:1.02}
  .heroA p{color:rgba(255,255,255,.85);font-size:1.08rem;margin:16px 0 24px;max-width:480px}
  .heroA .cta{display:flex;gap:14px;flex-wrap:wrap}

  /* HERO B — split */
  .heroB{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:64px 0 56px}
  .heroB h1{color:var(--ink)}
  .heroB .badge{display:inline-flex;align-items:center;gap:8px;background:var(--wash);color:var(--plum);font-size:.82rem;font-weight:600;padding:7px 14px;border-radius:50px;margin-bottom:22px}
  .heroB p{font-size:1.15rem;margin:20px 0 30px;max-width:480px}
  .heroB .cta{display:flex;gap:14px;flex-wrap:wrap}
  .heroB .media{aspect-ratio:6/7;border-radius:18px;background:var(--wash);border:1.5px dashed var(--lav);display:flex;align-items:center;justify-content:center}
  .heroB .media .ph{color:var(--plum);font-size:.82rem;text-align:center;max-width:260px;line-height:1.7;padding:24px}
  .heroB .ph strong{display:block;margin-bottom:6px;font-size:.9rem}

  /* image placeholder generic */
  .imgph{background:var(--wash);border:1.5px dashed var(--lav);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--plum);font-size:.8rem;text-align:center;line-height:1.65;padding:22px}
  .imgph strong{display:block;font-size:.88rem;margin-bottom:5px}

  /* section base */
  section{padding:52px 0}
  .sec-head{text-align:center;max-width:640px;margin:0 auto 32px}
  .sec-head h2{margin:8px 0 10px}
  .sec-head p{font-size:1.05rem}

  /* trust */
  .trust{padding:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--wash-2)}
  .trust p{text-align:center;font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--lav);margin-bottom:24px}
  .logos{display:flex;justify-content:center;gap:46px;flex-wrap:wrap;align-items:center}
  .logos .lg{width:120px;height:38px;background:#E4DAEA;border-radius:6px;opacity:.7}
  .badges{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}
  .badge-cred{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--white);font-size:14px;font-weight:600;color:var(--ink);transition:border-color .2s,transform .2s}
  .badge-cred:hover{border-color:var(--lav);transform:translateY(-2px)}
  .badge-cred svg{width:18px;height:18px;stroke:var(--plum);fill:none;stroke-width:1.7}

  /* value cards */
  .grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
  .vcard{background:var(--wash-2);border:1px solid var(--line);border-radius:var(--r-md);padding:28px 24px}
  .vcard .ico{width:46px;height:46px;border-radius:11px;background:var(--plum);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .vcard .ico svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8}
  .vcard h3{margin-bottom:8px}
  .vcard p{font-size:.92rem}

  /* who we are */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
  .split .media{aspect-ratio:5/4}
  .split h2{margin:14px 0 18px}
  .split p{font-size:1.05rem;margin-bottom:16px}

  /* services */
  .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .scard{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--white);transition:.2s}
  .scard:hover{border-color:var(--lav);transform:translateY(-3px);box-shadow:var(--shadow-card)}
  .scard .media{aspect-ratio:4/3;border-radius:0}
  .scard .body{padding:24px}
  .scard h3{margin-bottom:8px}
  .scard p{font-size:.92rem;margin-bottom:14px}
  .scard .more{color:var(--plum);font-weight:600;font-size:.9rem}

  /* how it works */
  .how{background:var(--wash-2)}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .step{padding:28px;border-radius:16px;background:var(--white);border:1px solid var(--line)}
  .step .num{font-size:2.2rem;font-weight:800;color:var(--lav);letter-spacing:-.03em;line-height:1}
  .step h3{margin:14px 0 8px}
  .step p{font-size:.92rem}

  /* testimonials */
  .tgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
  .tcard{border:1px solid var(--line);border-radius:16px;padding:30px;background:var(--wash-2)}
  .tgrid-3{grid-template-columns:repeat(3,1fr)}
  .tgrid-3 .tcard{padding:26px}
  .tgrid-3 .quote{font-size:1rem}
  .tcard .stars{color:var(--plum);font-size:1rem;letter-spacing:3px;margin-bottom:14px}
  .tcard .quote{font-size:1.05rem;color:var(--ink);line-height:1.6;margin-bottom:18px;font-weight:500}
  .tcard .who{display:flex;align-items:center;gap:12px}
  .tcard .av{width:42px;height:42px;border-radius:50%;background:var(--plum);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}
  .tcard .who .nm{font-weight:600;font-size:.92rem;color:var(--ink)}
  .tcard .who .rl{font-size:.82rem;color:var(--muted)}

  /* resources */
  .rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .rcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--white);transition:.2s}
  .rcard:hover{border-color:var(--lav)}
  .rcard .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--wash),#EFE2F4);display:flex;align-items:center;justify-content:center;color:var(--lav);font-size:.8rem}
  .rcard .body{padding:22px}
  .rcard .cat{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--lav)}
  .rcard h3{font-size:1.05rem;margin:8px 0 0}

  /* CTA band */
  .ctaband{position:relative;border-radius:24px;overflow:hidden;background:var(--plum);padding:64px 56px;text-align:center;margin:0 0 0}
  .ctaband .shape{position:absolute;border-radius:50%;opacity:.18}
  .ctaband .s1{width:280px;height:280px;background:var(--lav);top:-120px;right:-60px}
  .ctaband .s2{width:200px;height:200px;background:#6B3A7E;bottom:-90px;left:-40px}
  .ctaband h2{color:#fff;position:relative;z-index:2;max-width:600px;margin:0 auto 16px}
  .ctaband p{color:rgba(255,255,255,.82);position:relative;z-index:2;font-size:1.1rem;max-width:520px;margin:0 auto 28px}
  .ctaband .cta{position:relative;z-index:2;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

  /* footer */
  footer{background:var(--ink);color:#fff;padding:48px 0 28px}
  .fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;margin-bottom:44px}
  footer .brand{margin-bottom:16px}
  footer .brand img{height:30px;width:auto;display:block}
  footer .mission{color:rgba(255,255,255,.6);font-size:.92rem;max-width:280px;line-height:1.7}
  footer h4{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px;font-weight:600}
  footer ul{list-style:none}
  footer li{margin-bottom:11px}
  footer li a{color:rgba(255,255,255,.78);font-size:.92rem}
  footer li a:hover{color:#fff}
  .news input{width:100%;padding:12px 14px;border-radius:9px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:.9rem;margin-bottom:12px}
  .news input::placeholder{color:rgba(255,255,255,.4)}
  .news .btn{width:100%;justify-content:center}
  .fbar{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.5);font-size:.85rem}

  /* responsive — everything centers/stacks up to 980px */
  @media(max-width:980px){
    .nav-links{display:none}
    .nav-cta .btn-g{display:none}
    .hamburger{display:block}
    .heroB{grid-template-columns:1fr;gap:36px;text-align:center;padding:48px 0}
    .heroB .badge,.heroB .cta{justify-content:center}
    .heroB p{margin-left:auto;margin-right:auto}
    .heroB .media{max-width:380px;margin:0 auto;width:100%}
    .heroA .inner{padding:40px 32px;max-width:100%;text-align:center}
    .heroA .scrim{background:linear-gradient(180deg,rgba(58,18,71,.86),rgba(58,18,71,.92))}
    .heroA .cta{justify-content:center}
    .grid-4{grid-template-columns:repeat(2,1fr)}
    .split{grid-template-columns:1fr;gap:34px;text-align:center}
    .split .media{max-width:480px;margin:0 auto;width:100%}
    .split .cta{justify-content:center;display:flex}
    .grid-3,.rgrid,.steps{grid-template-columns:1fr;max-width:460px;margin:0 auto}
    .tgrid,.tgrid-3{grid-template-columns:1fr}
    .fgrid{grid-template-columns:1fr 1fr;gap:32px;text-align:left}
    .ctaband{padding:48px 28px}
  }

  /* ============ ADDED COMPONENTS ============ */
  /* subtle plum dot-grid texture utility */
  .tex-dots{position:relative}
  .tex-dots::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(72,24,88,.07) 1px,transparent 1px);background-size:22px 22px;pointer-events:none;z-index:0}
  .tex-dots > *{position:relative;z-index:1}
  .tex-mesh{position:relative;overflow:hidden}
  .tex-mesh::before{content:"";position:absolute;top:-20%;right:-10%;width:520px;height:520px;background:radial-gradient(circle,rgba(152,128,168,.16),transparent 62%);pointer-events:none;z-index:0}
  .tex-mesh > *{position:relative;z-index:1}

  /* stats band */
  .stats{background:var(--plum);color:#fff;padding:40px 0}
  .stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
  .stats .stat .n{font-size:clamp(2rem,3.4vw,42px);font-weight:800;letter-spacing:-.03em;line-height:1;color:#fff}
  .stats .stat .l{font-size:14px;color:rgba(255,255,255,.74);margin-top:10px;font-weight:500}
  .stats .stat .n .suf,.stats .stat .n .pre{color:var(--lav)}

  /* alternating feature rows */
  .feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:88px}
  .feature:last-child{margin-bottom:0}
  .feature.flip .ftext{order:2}
  .feature.flip .fmedia{order:1}
  .fmedia{aspect-ratio:4/3;border-radius:var(--r-lg);background-size:cover;background-position:center;border:1px solid var(--line);box-shadow:var(--shadow-card)}
  .ftext .tagrow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
  .ftext h3{font-size:clamp(1.6rem,2.6vw,32px);margin:6px 0 14px;line-height:1.12}
  .ftext p{font-size:1.05rem;margin-bottom:18px}
  .flist{list-style:none;margin:0 0 8px}
  .flist li{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;color:var(--ink);font-size:1rem}
  .flist li svg{width:20px;height:20px;flex:none;stroke:var(--plum);fill:none;stroke-width:2;margin-top:2px}

  /* tag pills */
  .tag{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.02em;padding:5px 12px;border-radius:var(--r-pill);background:var(--wash);color:var(--plum)}
  .tag.alt{background:rgba(152,128,168,.16);color:var(--plum-d)}

  /* richer card additions */
  .vcard .tag,.scard .body .tag{margin-bottom:12px}
  .scard .body .meta{display:flex;align-items:center;gap:10px;margin-bottom:10px}

  /* FAQ accordion */
  .faq{max-width:840px;margin:0 auto}
  .faq-item{border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:14px;background:var(--white);overflow:hidden;transition:border-color .2s,box-shadow .2s}
  .faq-item[open]{border-color:var(--lav);box-shadow:var(--shadow-card)}
  .faq-item summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:600;font-size:1.08rem;color:var(--ink)}
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary .chev{flex:none;width:22px;height:22px;border-radius:50%;background:var(--wash);display:flex;align-items:center;justify-content:center;transition:transform .25s,background .2s;color:var(--plum);font-size:14px}
  .faq-item[open] summary .chev{transform:rotate(45deg);background:var(--plum);color:#fff}
  .faq-item .ans{padding:0 24px 22px;color:var(--muted);font-size:1rem;line-height:1.7}

  @media(max-width:980px){
    .stats .grid{grid-template-columns:repeat(2,1fr);gap:36px 24px}
    .feature{grid-template-columns:1fr;gap:28px;margin-bottom:56px;text-align:center}
    .feature.flip .ftext,.feature.flip .fmedia{order:initial}
    .fmedia{max-width:520px;margin:0 auto;width:100%}
    .ftext .tagrow,.flist{justify-content:center}
    .flist li{text-align:left}
    .feature .cta,.feature a.btn{margin:0 auto}
  }
  @media(max-width:560px){
    .stats .grid{grid-template-columns:1fr 1fr;gap:28px 16px}
  }

  /* ============ SECURITY / COMPARISON / CONTACT ============ */
  /* security band */
  .security{background:var(--wash-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .sec-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:8px}
  .sfeat{text-align:center;padding:12px}
  .sfeat .ic{width:52px;height:52px;border-radius:14px;background:var(--white);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
  .sfeat .ic svg{width:24px;height:24px;stroke:var(--plum);fill:none;stroke-width:1.8}
  .sfeat h4{font-size:15px;font-weight:600;margin-bottom:6px;color:var(--ink)}
  .sfeat p{font-size:13.5px;line-height:1.55}

  /* comparison table */
  .compare{max-width:920px;margin:0 auto;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--white)}
  .ctable{width:100%;border-collapse:collapse}
  .ctable th,.ctable td{padding:18px 20px;text-align:center;border-bottom:1px solid var(--line);font-size:15px}
  .ctable thead th{background:var(--wash-2);font-weight:600;color:var(--ink);font-size:14px}
  .ctable thead th.us{background:var(--plum);color:#fff}
  .ctable tbody td:first-child{text-align:left;font-weight:500;color:var(--ink)}
  .ctable td.us{background:rgba(72,24,88,.04)}
  .ctable tr:last-child td{border-bottom:none}
  .ctable .yes{color:var(--plum)}
  .ctable .yes svg{width:20px;height:20px;stroke:var(--plum);fill:none;stroke-width:2.4}
  .ctable .no{color:rgba(32,33,40,.32)}
  .ctable .no svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.4}
  .ctable .us .yes{color:#fff}.ctable td.us .yes svg{stroke:#fff}

  /* contact / book a call */
  .contact{background:var(--wash-2);color:var(--ink);border-top:1px solid var(--line)}
  .contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
  .contact h2{color:var(--ink)}
  .contact .lead{color:var(--muted);font-size:1.1rem;margin:16px 0 28px;max-width:440px}
  .contact .clist{list-style:none;margin:0}
  .contact .clist li{display:flex;align-items:center;gap:14px;margin-bottom:18px;color:var(--ink);font-size:1rem}
  .contact .clist li .ci{width:42px;height:42px;border-radius:12px;background:var(--wash);display:flex;align-items:center;justify-content:center;flex:none}
  .contact .clist li .ci svg{width:20px;height:20px;stroke:var(--plum);fill:none;stroke-width:1.8}
  .contact .clist li small{display:block;color:var(--muted);font-size:13px;margin-top:2px}
  .contact-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-soft)}
  .contact-card h3{color:var(--ink);margin-bottom:6px}
  .contact-card p{font-size:14px;margin-bottom:20px}
  .field{margin-bottom:14px}
  .field label{display:block;font-size:13px;font-weight:500;color:var(--ink);margin-bottom:6px}
  .field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line-strong);border-radius:var(--r-sm);font-size:15px;font-family:inherit;color:var(--ink);background:var(--white);transition:border-color .18s,box-shadow .18s}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--plum);box-shadow:0 0 0 3px rgba(72,24,88,.10)}
  .contact-card .btn-p{width:100%;justify-content:center;margin-top:6px}
  .contact-card .fine{font-size:12px;color:var(--muted);text-align:center;margin-top:12px}

  @media(max-width:980px){
    .sec-feats{grid-template-columns:repeat(2,1fr);gap:24px 16px}
    .contact-grid{grid-template-columns:1fr;gap:36px}
    .contact .clist{max-width:420px;margin:0 auto}
    .compare{overflow-x:auto}
    .ctable{min-width:560px}
  }
  @media(max-width:560px){
    .sec-feats{grid-template-columns:1fr 1fr;gap:20px 12px}
  }

  /* ============ ANIMATIONS ============ */
  @media (prefers-reduced-motion: no-preference){

    /* scroll reveal — sections rise + fade in */
    .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
    .reveal.in{opacity:1;transform:none}
    /* stagger children */
    .reveal-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.22,.61,.36,1),transform .6s cubic-bezier(.22,.61,.36,1)}
    .reveal-stagger.in > *{opacity:1;transform:none}
    .reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
    .reveal-stagger.in > *:nth-child(2){transition-delay:.13s}
    .reveal-stagger.in > *:nth-child(3){transition-delay:.21s}
    .reveal-stagger.in > *:nth-child(4){transition-delay:.29s}

    /* hero entrance */
    @keyframes heroRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
    .heroA .inner > *{animation:heroRise .8s cubic-bezier(.22,.61,.36,1) both}
    .heroA .inner > *:nth-child(1){animation-delay:.10s}
    .heroA .inner > *:nth-child(2){animation-delay:.22s}
    .heroA .inner > *:nth-child(3){animation-delay:.34s}
    @keyframes heroZoom{from{transform:scale(1.06)}to{transform:scale(1)}}
    .heroA .bg{animation:heroZoom 1.6s cubic-bezier(.22,.61,.36,1) both}

    /* button micro-interactions */
    .btn{transition:background .18s,color .18s,border-color .18s,transform .18s cubic-bezier(.22,.61,.36,1),box-shadow .18s}
    .btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(72,24,88,.28)}
    .btn-g:hover,.btn-w:hover,.btn-ghost-w:hover{transform:translateY(-2px)}
    .btn:active{transform:translateY(0) scale(.98)}

    /* card lift */
    .vcard{transition:transform .25s cubic-bezier(.22,.61,.36,1),border-color .25s,box-shadow .25s}
    .vcard:hover{transform:translateY(-4px);border-color:var(--lav);box-shadow:var(--shadow-soft)}
    .vcard .ico{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
    .vcard:hover .ico{transform:scale(1.08) rotate(-3deg)}
    .scard .media,.scard{transition:transform .25s cubic-bezier(.22,.61,.36,1),border-color .25s,box-shadow .25s}
    .tcard,.rcard,.step{transition:transform .25s cubic-bezier(.22,.61,.36,1),border-color .25s,box-shadow .25s}
    .tcard:hover,.rcard:hover,.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}

    /* nav links underline grow */
    .nav-links a{position:relative}
    .nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--plum);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.22,.61,.36,1)}
    .nav-links a:hover::after{transform:scaleX(1)}

    /* header shadow on scroll */
    header{transition:box-shadow .3s,background .3s}
    header.scrolled{box-shadow:0 4px 24px rgba(72,24,88,.08)}

    /* trust logos breathe in */
    .logos .lg{transition:opacity .3s,transform .3s}
    .logos .lg:hover{opacity:1;transform:scale(1.04)}

    /* CTA band animated sheen */
    .ctaband .shape{animation:floatShape 9s ease-in-out infinite}
    .ctaband .s2{animation-duration:11s;animation-direction:reverse}
    @keyframes floatShape{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-14px)}}

    /* service card image subtle zoom on hover */
    .scard{overflow:hidden}
    .scard:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}

    /* step number count-up shimmer */
    .step .num{transition:color .3s}
    .step:hover .num{color:var(--plum)}
  }
  @media(max-width:560px){
    .grid-4{grid-template-columns:1fr;max-width:340px;margin:0 auto}
    .fgrid{grid-template-columns:1fr;text-align:center}
    .news{max-width:320px;margin:0 auto}
    .fbar{justify-content:center;text-align:center}
    .logos{gap:24px}
    .wrap{padding:0 20px}
  }
/* ===== WordPress integration additions ===== */
/* Admin bar offset for sticky header */
.admin-bar header{top:32px}
@media screen and (max-width:782px){.admin-bar header{top:46px}}

/* Mobile dropdown menu (hamburger open state) */
@media(max-width:980px){
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--white);border-bottom:1px solid var(--line);
    padding:16px 24px;gap:14px;box-shadow:var(--shadow-card);z-index:60
  }
  .nav-links.open a{padding:6px 0}
  header{position:sticky}
}

/* WordPress core alignment & block defaults inside entry content */
.entry-content img{max-width:100%;height:auto;border-radius:var(--r-md)}
.entry-content h2{font-size:1.6rem;margin:1.4em 0 .5em}
.entry-content h3{font-size:1.25rem;margin:1.2em 0 .4em}
.entry-content p{margin-bottom:1em}
.entry-content a{color:var(--plum);text-decoration:underline}
.entry-content ul,.entry-content ol{margin:0 0 1em 1.4em}
.entry-content blockquote{border-left:3px solid var(--plum);padding-left:18px;color:var(--muted);margin:1.2em 0}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.alignright{float:right;margin:0 0 1em 1.5em}
.alignleft{float:left;margin:0 1.5em 1em 0}

/* Pagination */
.pagination,.posts-navigation{display:flex;gap:8px;flex-wrap:wrap}
.page-numbers{padding:8px 14px;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink);text-decoration:none}
.page-numbers.current{background:var(--plum);color:#fff;border-color:var(--plum)}

/* ===== ADDED MOTION ===== */
@media (prefers-reduced-motion: no-preference){

  /* scroll progress bar */
  .pf-progress{
    position:fixed;top:0;left:0;height:3px;width:100%;
    background:linear-gradient(90deg,var(--plum),var(--lav));
    transform:scaleX(0);transform-origin:left;z-index:200;
    transition:transform .1s linear
  }
  .admin-bar .pf-progress{top:32px}
  @media screen and (max-width:782px){.admin-bar .pf-progress{top:46px}}

  /* hero bg eases its transform */
  .heroA .bg{transition:transform .1s linear,filter .4s}

  /* buttons ease the magnetic return */
  .btn{transition:transform .25s cubic-bezier(.34,1.56,.64,1),background .18s,color .18s,border-color .18s,box-shadow .18s}

  /* cards ease the tilt return */
  .vcard,.scard{transition:transform .3s cubic-bezier(.22,.61,.36,1),border-color .25s,box-shadow .25s;transform-style:preserve-3d}

  /* FAQ items rise in with stagger */
  .faq-item{opacity:0;transform:translateY(16px);transition:opacity .5s,transform .5s,border-color .2s,box-shadow .2s}
  .faq-item.motion-in{opacity:1;transform:none}
  .faq-item:nth-child(2){transition-delay:.06s}
  .faq-item:nth-child(3){transition-delay:.12s}
  .faq-item:nth-child(4){transition-delay:.18s}
  .faq-item:nth-child(5){transition-delay:.24s}

  /* security icons pop in + gentle float */
  .sfeat{opacity:0;transform:translateY(18px);transition:opacity .5s,transform .5s}
  .sfeat.motion-in{opacity:1;transform:none}
  .sfeat.motion-in .ic{animation:pfFloat 4s ease-in-out infinite}
  .sfeat:nth-child(2).motion-in .ic{animation-delay:.4s}
  .sfeat:nth-child(3).motion-in .ic{animation-delay:.8s}
  .sfeat:nth-child(4).motion-in .ic{animation-delay:1.2s}
  @keyframes pfFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

  /* credential badges pop in */
  .badge-cred{opacity:0;transform:translateY(12px) scale(.96);transition:opacity .45s,transform .45s,border-color .2s}
  .badge-cred.motion-in{opacity:1;transform:none}
  .badge-cred:nth-child(2){transition-delay:.08s}
  .badge-cred:nth-child(3){transition-delay:.16s}
  .badge-cred:nth-child(4){transition-delay:.24s}

  /* animated gradient underline sweep on section eyebrows */
  .eyebrow{position:relative;display:inline-block}
  .sec-head .eyebrow::after{
    content:"";position:absolute;left:50%;bottom:-6px;width:24px;height:2px;
    background:linear-gradient(90deg,var(--plum),var(--lav));
    transform:translateX(-50%) scaleX(0);transform-origin:center;
    transition:transform .5s ease .2s
  }
  .sec-head.in .eyebrow::after,.reveal.in .eyebrow::after{transform:translateX(-50%) scaleX(1)}

  /* service card image zoom on hover */
  .scard .media{transition:transform .5s cubic-bezier(.22,.61,.36,1)}
  .scard:hover .media{transform:scale(1.05)}

  /* stat tiles subtle pulse when counting completes */
  .stats .stat .n{transition:transform .3s}
  .stats .stat:hover .n{transform:scale(1.04)}

  /* testimonial cards gentle lift already exists; add quote-mark fade */
  .tcard .stars{transition:transform .3s}
  .tcard:hover .stars{transform:scale(1.08)}

  /* CTA band shimmer sweep */
  .ctaband::after{
    content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
    transform:skewX(-20deg);animation:pfShimmer 6s ease-in-out infinite;pointer-events:none
  }
  @keyframes pfShimmer{0%{left:-60%}50%{left:120%}100%{left:120%}}
}

/* ===== ABOUT PAGE ===== */
.ab-hero{padding:72px 0 56px}
.ab-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.ab-hero h1{font-size:clamp(2.2rem,4.6vw,54px);margin:14px 0 18px;line-height:1.03}
.ab-hero p{font-size:1.15rem;max-width:520px}
.ab-hero-media{aspect-ratio:4/3;border-radius:var(--r-lg);background-size:cover;background-position:center;border:1px solid var(--line);box-shadow:var(--shadow-card)}

.ab-mission{background:var(--plum);color:#fff;text-align:center;position:relative;overflow:hidden}
.ab-mission-inner{max-width:840px;margin:0 auto;position:relative;z-index:2}
.ab-mission .eyebrow{display:inline-block;margin-bottom:20px}
.ab-mission-quote{font-size:clamp(1.5rem,3.4vw,34px);line-height:1.35;font-weight:600;color:#fff;letter-spacing:-.01em}

/* Founder feature */
.founder-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.founder-media{aspect-ratio:1;border-radius:var(--r-lg);background-size:cover;background-position:center;border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.founder-quote{font-size:clamp(1.3rem,2.6vw,28px);line-height:1.4;font-weight:600;color:var(--ink);letter-spacing:-.01em;border:none;padding:0;margin:14px 0 24px;position:relative}
.founder-quote::before{content:"\201C";position:absolute;top:-28px;left:-8px;font-size:80px;color:var(--lav);opacity:.4;font-family:Georgia,serif;line-height:1}
.founder-name{font-weight:700;font-size:1.1rem;color:var(--plum)}
.founder-role{font-size:.92rem;color:var(--muted);margin-top:2px}

/* Office gallery — asymmetric grid */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:200px 200px;gap:16px}
.gallery-item{background-size:cover;background-position:center;border-radius:var(--r-md);border:1px solid var(--line)}
.gallery-item-1{grid-column:span 2;grid-row:span 2}
.gallery-item-2{grid-column:span 2}
.gallery-item-3{grid-column:span 1}
.gallery-item-4{grid-column:span 1}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.member{text-align:center}
.member-photo{aspect-ratio:1;border-radius:var(--r-lg);background:var(--wash);display:flex;align-items:center;justify-content:center;margin-bottom:16px;border:1px solid var(--line);overflow:hidden}
.member-initials{font-size:2rem;font-weight:700;color:var(--lav);letter-spacing:.02em}
.member-name{font-weight:600;font-size:1.05rem;color:var(--ink)}
.member-role{font-size:.9rem;color:var(--muted);margin-top:3px}

@media(max-width:980px){
  .ab-hero-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .ab-hero p{margin-left:auto;margin-right:auto}
  .ab-hero-media{max-width:520px;margin:0 auto;width:100%}
  .founder-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .founder-media{max-width:360px;margin:0 auto;width:100%}
  .founder-quote::before{display:none}
  .gallery-grid{grid-template-rows:auto}
  .gallery-item{aspect-ratio:4/3;height:auto}
  .gallery-item-1{grid-column:span 2;grid-row:span 1}
  .gallery-item-2{grid-column:span 2}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:24px 16px}
  .ab-hero{padding:48px 0 40px}
}
@media(max-width:560px){
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-item-1,.gallery-item-2{grid-column:span 2}
  .team-grid{grid-template-columns:1fr 1fr;gap:18px 12px}
}

/* ===== LOGO WATERMARK on purple bands ===== */
/* Path is relative to this CSS file: assets/css/theme.css -> ../images/ */
.stats,
.ctaband,
.ab-mission{position:relative;overflow:hidden}

.stats::before,
.ctaband::before,
.ab-mission::before{
  content:"";
  position:absolute;
  right:-40px;
  bottom:-60px;
  width:340px;
  height:373px;
  background-image:url('../images/watermark.png');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:right bottom;
  opacity:.06;
  pointer-events:none;
  z-index:0;
}

/* keep content above watermark */
.stats .wrap,
.ctaband h2,
.ctaband p,
.ctaband .cta,
.ctaband .shape,
.ab-mission-inner{position:relative;z-index:1}

/* stats sits a touch larger + left for variety */
.stats::before{right:auto;left:-50px;top:-50px;bottom:auto;width:300px;height:329px;background-position:left top;opacity:.05}

/* mission watermark centered-ish and bigger */
.ab-mission::before{width:420px;height:461px;right:-80px;bottom:-100px;opacity:.07}

/* hero scrim watermark — subtle on the plum gradient side */
.heroA{position:relative}
.heroA .scrim::after{
  content:"";
  position:absolute;
  left:24px;
  bottom:-40px;
  width:280px;
  height:307px;
  background-image:url('../images/watermark.png');
  background-size:contain;
  background-repeat:no-repeat;
  opacity:.05;
  pointer-events:none;
}
@media(max-width:980px){
  .heroA .scrim::after{width:180px;height:197px;left:50%;transform:translateX(-50%)}
  .stats::before,.ctaband::before,.ab-mission::before{width:220px;height:241px}
}

/* ===== EXPANDED LOGO-ICON USAGE ===== */

/* 1. FOOTER watermark (white icon, bottom-right) */
footer{position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;right:-50px;bottom:-70px;
  width:360px;height:395px;
  background:url('../images/watermark.png') no-repeat right bottom;
  background-size:contain;opacity:.045;pointer-events:none;z-index:0
}
footer .wrap{position:relative;z-index:1}

/* 2. Replace dot-grid with faint plum icon on .tex-dots sections */
.tex-dots::before{
  background-image:none !important;
}
.tex-dots{position:relative;overflow:hidden}
.tex-dots::after{
  content:"";position:absolute;right:-60px;top:-40px;
  width:380px;height:416px;
  background:url('../images/watermark-plum.png') no-repeat right top;
  background-size:contain;opacity:.035;pointer-events:none;z-index:0
}
.tex-dots > *{position:relative;z-index:1}

/* 3. Icon fade-in on card hover (value + service cards) */
.vcard,.scard{position:relative;overflow:hidden}
.vcard::after,.scard::after{
  content:"";position:absolute;right:-30px;bottom:-30px;
  width:120px;height:131px;
  background:url('../images/watermark-plum.png') no-repeat center;
  background-size:contain;opacity:0;transform:scale(.9) rotate(-6deg);
  transition:opacity .35s,transform .35s;pointer-events:none;z-index:0
}
.vcard:hover::after,.scard:hover::after{opacity:.06;transform:scale(1) rotate(0)}
.vcard > *,.scard > *{position:relative;z-index:1}

/* 4. Section divider — small centered icon "breath mark" */
.pf-divider{display:flex;align-items:center;justify-content:center;padding:28px 0}
.pf-divider span{
  width:30px;height:33px;
  background:url('../images/watermark-plum.png') no-repeat center;
  background-size:contain;opacity:.22
}

/* ===== GLOBAL MOBILE CENTERING (≤980px) ===== */
@media(max-width:980px){
  /* Text blocks center across the board */
  .heroA .inner,
  .split > div,
  .ftext,
  .ab-hero-text,
  .founder-text,
  .who-text,
  .contact-grid > div:first-child{
    text-align:center;
  }

  /* Constrain and center paragraphs so they don't stretch edge-to-edge */
  .heroA .inner p,
  .split p,
  .ftext p,
  .ab-hero-text p,
  .founder-quote,
  .contact .lead{
    margin-left:auto;margin-right:auto;
  }

  /* Center all button groups / CTAs */
  .heroA .cta,
  .heroB .cta,
  .ctaband .cta,
  .feature .cta,
  .split .cta,
  .contact .cta{
    justify-content:center;display:flex;flex-wrap:wrap;
  }

  /* Single buttons that aren't in a flex row */
  .split .btn,
  .ftext .btn,
  .ab-hero-text .btn,
  .who .btn,
  .ab-founder .btn{
    display:inline-flex;
  }

  /* Center feature checklists and contact list */
  .flist,
  .contact .clist{
    display:inline-block;text-align:left;margin-left:auto;margin-right:auto;
  }
  .flist li,
  .contact .clist li{justify-content:flex-start}

  /* Center the founder signature + quote mark */
  .founder-sig{text-align:center}
  .founder-quote::before{left:50%;transform:translateX(-50%);top:-34px}

  /* Eyebrows center naturally with their parent text-align */
  /* Contact: center the methods column, form stays full width */
  .contact .clist{display:inline-block}

  /* Tags / badge rows center */
  .ftext .tagrow{justify-content:center;display:flex;flex-wrap:wrap}

  /* Center card content for full mobile consistency */
  .vcard,.scard .body,.step,.tcard,.sfeat{text-align:center}
  .vcard .ico,.step .num{margin-left:auto;margin-right:auto}
  .vcard .tag,.scard .body .tag{display:inline-block}
  .scard .more{display:inline-block}
  .tcard .who{justify-content:center}
  .tcard .stars{text-align:center}
  /* FAQ summaries stay left (better for reading Q&A) */
  .member{text-align:center}
}

@media(max-width:560px){
  /* Tighten paragraph max-widths on phones so centered text reads well */
  .heroA .inner p,
  .split p,
  .ab-hero-text p,
  .contact .lead,
  .ab-hero p{max-width:90%}
}

/* ===== NARROW-PHONE HEADER FIX (Infinix Note 30 etc, ~360px) ===== */
@media(max-width:480px){
  .nav{height:64px}
  .brand img{height:28px}
  .nav-cta{gap:8px}
  .nav-cta .btn{padding:9px 14px;font-size:.82rem}
  .hamburger{font-size:1.5rem;padding:0 2px}
  .wrap{padding-left:16px;padding-right:16px}
}
@media(max-width:380px){
  .brand img{height:25px}
  .nav-cta .btn{padding:8px 12px;font-size:.78rem;border-radius:8px}
  .nav-cta{gap:6px}
  .wrap{padding-left:14px;padding-right:14px}
}

/* ===== WHATSAPP FLOATING BUTTON (Plumfiles plum) ===== */
.pf-whatsapp{
  position:fixed;
  right:22px;bottom:22px;
  z-index:300;
  display:flex;align-items:center;gap:0;
  text-decoration:none;
}
.pf-wa-icon{
  width:58px;height:58px;border-radius:50%;
  background:var(--plum);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(72,24,88,.34);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),background .2s,box-shadow .25s;
  position:relative;
}
.pf-whatsapp:hover .pf-wa-icon{
  background:var(--plum-d);
  transform:scale(1.08);
  box-shadow:0 10px 30px rgba(72,24,88,.42);
}
/* pulse ring */
.pf-wa-icon::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:var(--plum);opacity:.4;z-index:-1;
  animation:pfWaPulse 2.4s ease-out infinite;
}
@keyframes pfWaPulse{
  0%{transform:scale(1);opacity:.4}
  70%{transform:scale(1.6);opacity:0}
  100%{transform:scale(1.6);opacity:0}
}
/* tooltip */
.pf-wa-tip{
  background:#fff;color:var(--ink);
  font-size:14px;font-weight:600;
  padding:9px 14px;border-radius:var(--r-pill);
  margin-right:12px;white-space:nowrap;
  box-shadow:var(--shadow-card);
  border:1px solid var(--line);
  opacity:0;transform:translateX(10px);
  transition:opacity .25s,transform .25s;
  pointer-events:none;
}
.pf-whatsapp:hover .pf-wa-tip{opacity:1;transform:translateX(0)}

@media(prefers-reduced-motion:reduce){
  .pf-wa-icon::before{animation:none;display:none}
}
@media(max-width:560px){
  .pf-whatsapp{right:16px;bottom:16px}
  .pf-wa-icon{width:52px;height:52px}
  .pf-wa-icon svg{width:26px;height:26px}
  .pf-wa-tip{display:none}
}
/* lift above admin bar isn't needed (fixed to viewport bottom) */

/* ===== TESTIMONIAL CAROUSEL ===== */
.testi-carousel{position:relative;padding:0 8px}
.tc-viewport{overflow:hidden}
.tc-track{display:flex;transition:transform .5s cubic-bezier(.22,.61,.36,1);will-change:transform}
.tc-slide{flex:0 0 33.333%;box-sizing:border-box;padding:0 12px}
.tc-slide .tcard{height:100%;background:var(--wash-2)}
.tc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:46px;height:46px;border-radius:50%;
  background:var(--white);border:1px solid var(--line);
  color:var(--plum);font-size:24px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:3;transition:.2s;box-shadow:var(--shadow-card)
}
.tc-arrow:hover{background:var(--plum);color:#fff;border-color:var(--plum);transform:translateY(-50%) scale(1.06)}
.tc-prev{left:-10px}
.tc-next{right:-10px}
.tc-arrow:disabled{opacity:.35;cursor:default}
.tc-arrow:disabled:hover{background:var(--white);color:var(--plum);border-color:var(--line);transform:translateY(-50%)}
.tc-dots{display:flex;justify-content:center;gap:8px;margin-top:28px}
.tc-dot{width:8px;height:8px;border-radius:50%;background:var(--line-strong);border:none;cursor:pointer;padding:0;transition:.25s}
.tc-dot.active{background:var(--plum);width:26px;border-radius:4px}

@media(max-width:980px){
  .tc-slide{flex:0 0 50%}
  .tc-prev{left:-4px}.tc-next{right:-4px}
}
@media(max-width:680px){
  .tc-slide{flex:0 0 100%}
  .tc-arrow{width:40px;height:40px;font-size:20px}
  .tc-prev{left:-6px}.tc-next{right:-6px}
}

/* ===== STICKY GET-STARTED BAR ===== */
.pf-stickybar{
  position:fixed;left:0;right:0;bottom:0;z-index:250;
  background:var(--white);
  border-top:1px solid var(--line);
  box-shadow:0 -6px 24px rgba(72,24,88,.10);
  transform:translateY(110%);
  transition:transform .4s cubic-bezier(.22,.61,.36,1);
}
.pf-stickybar.show{transform:translateY(0)}
.pf-sb-inner{display:flex;align-items:center;gap:18px;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.pf-sb-text{font-weight:600;color:var(--ink);font-size:1.02rem;flex:1}
.pf-sb-btn{flex:none}
.pf-sb-close{
  flex:none;width:32px;height:32px;border-radius:50%;
  background:var(--wash-2);border:1px solid var(--line);
  color:var(--muted);font-size:20px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.2s
}
.pf-sb-close:hover{background:var(--wash);color:var(--plum)}
/* keep WhatsApp above the bar when bar is visible */
.pf-stickybar.show ~ .pf-whatsapp{bottom:90px}
.pf-whatsapp{transition:bottom .4s cubic-bezier(.22,.61,.36,1),transform .25s}

@media(max-width:680px){
  .pf-sb-inner{padding:12px 16px;gap:12px}
  .pf-sb-text{font-size:.9rem}
  .pf-sb-btn{padding:10px 16px;font-size:.85rem}
  .pf-stickybar.show ~ .pf-whatsapp{bottom:78px}
}
@media(max-width:420px){
  .pf-sb-text{display:none}
  .pf-sb-inner{justify-content:space-between}
  .pf-sb-btn{flex:1;justify-content:center}
}

/* ===== CONTACT FORM ===== */
.pf-contact-form .pf-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.pf-contact-form .pf-form-submit{width:100%;justify-content:center;margin-top:6px;cursor:pointer}
.pf-contact-form .pf-form-submit:disabled{opacity:.7;cursor:default}
.pf-form-status{font-size:14px;margin-top:12px;padding:10px 14px;border-radius:var(--r-sm);display:none}
.pf-form-status.ok{display:block;background:rgba(72,24,88,.07);color:var(--plum);border:1px solid rgba(72,24,88,.18)}
.pf-form-status.err{display:block;background:#fdeaea;color:#a3261f;border:1px solid #f3c2bd}

/* ===== SERVICES PAGE ===== */
.sv-detail{padding:64px 0}
.sv-detail-tight{padding-top:0}
.sv-detail .media{aspect-ratio:4/3;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.sv-detail .split{align-items:center}
/* alternate the image to the right */
.sv-flip .split{direction:rtl}
.sv-flip .split > *{direction:ltr}
.sv-points{list-style:none;margin:20px 0 28px;padding:0}
.sv-points li{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;font-size:1rem;color:var(--ink)}
.sv-tick{flex:none;width:24px;height:24px;border-radius:50%;background:var(--wash);display:flex;align-items:center;justify-content:center;margin-top:1px}
.sv-tick svg{width:14px;height:14px;stroke:var(--plum);fill:none;stroke-width:2.6}
.steps-4{grid-template-columns:repeat(4,1fr)}

@media(max-width:980px){
  .sv-flip .split{direction:ltr}
  .sv-detail{padding:44px 0}
  .sv-points{display:inline-block;text-align:left}
  .steps-4{grid-template-columns:repeat(2,1fr);gap:28px 20px}
}
@media(max-width:560px){
  .steps-4{grid-template-columns:1fr}
}

/* ===== RESOURCES PAGE ===== */
/* featured post */
.rp-featured{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--white);text-decoration:none;transition:box-shadow .3s,transform .3s}
.rp-featured:hover{box-shadow:var(--shadow-card);transform:translateY(-3px)}
.rp-feat-media{min-height:340px;background:linear-gradient(135deg,var(--wash),var(--wash-2));display:flex;align-items:center;justify-content:center;overflow:hidden}
.rp-feat-ph{display:flex;align-items:center;justify-content:center}
.rp-feat-body{padding:40px;display:flex;flex-direction:column;justify-content:center}
.rp-feat-tag{font-size:13px;font-weight:600;color:var(--plum);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}
.rp-feat-body h2{font-size:clamp(1.5rem,2.6vw,30px);line-height:1.2;margin-bottom:14px;color:var(--ink)}
.rp-feat-body p{color:var(--muted);margin-bottom:18px}
.rp-feat-meta{font-size:13px;color:var(--muted);margin-bottom:18px}
.rp-feat-body .more{font-weight:600;color:var(--plum)}

/* filters */
.rp-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.rp-filter{padding:9px 18px;border-radius:var(--r-pill);border:1px solid var(--line-strong);background:var(--white);color:var(--ink);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:.2s}
.rp-filter:hover{border-color:var(--lav)}
.rp-filter.active{background:var(--plum);color:#fff;border-color:var(--plum)}

/* grid */
.rp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rp-card{display:flex;flex-direction:column;transition:opacity .35s,transform .35s,box-shadow .3s}
.rp-card.rp-hide{display:none}
.rp-card .body{display:flex;flex-direction:column;flex:1}
.rp-excerpt{color:var(--muted);font-size:.92rem;margin-top:8px;line-height:1.55}
.rp-meta{font-size:12.5px;color:var(--muted);margin-top:14px}
.rp-empty{text-align:center;color:var(--muted);padding:40px 0;font-size:1.05rem}
.rp-ph-note{text-align:center;color:var(--muted);font-size:14px;margin-top:28px}
.rp-ph-note strong{color:var(--plum)}

/* newsletter band */
.rp-news{position:relative;overflow:hidden;background:var(--plum);border-radius:24px;padding:56px;text-align:center;color:#fff}
.rp-news-inner{position:relative;z-index:2;max-width:560px;margin:0 auto}
.rp-news h2{color:#fff;font-size:clamp(1.5rem,3vw,30px);margin-bottom:12px}
.rp-news p{color:rgba(255,255,255,.82);margin-bottom:24px}
.rp-news-form{display:flex;gap:10px;max-width:460px;margin:0 auto}
.rp-news-form input{flex:1;padding:13px 16px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;font-size:15px;font-family:inherit}
.rp-news-form input::placeholder{color:rgba(255,255,255,.6)}
.rp-news-form input:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.18)}
.rp-news-form .btn-w{flex:none}
/* watermark on the plum newsletter band */
.rp-news::before{content:"";position:absolute;right:-50px;bottom:-70px;width:340px;height:373px;background:url('../images/watermark.png') no-repeat right bottom;background-size:contain;opacity:.06;pointer-events:none;z-index:0}

@media(max-width:980px){
  .rp-featured{grid-template-columns:1fr}
  .rp-feat-media{min-height:240px}
  .rp-feat-body{padding:30px}
  .rp-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .rp-grid{grid-template-columns:1fr}
  .rp-news{padding:40px 24px}
  .rp-news-form{flex-direction:column}
  .rp-news-form .btn-w{width:100%;justify-content:center}
}
