/* services.css — page-specific styles. Shared chrome (colours, nav, footer,
   fonts, buttons, animations) lives in site.css. */

/* NAV */
  .nav{position:fixed;top:0;left:0;right:0;z-index:40;background:rgba(251,253,251,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
/* PAGE HERO */
  .phero{position:relative;padding:150px 0 60px;overflow:hidden;background:#ffffff}
.phero .b{position:absolute;border-radius:50%;filter:blur(8px);z-index:0}
.phero .b1{width:340px;height:340px;background:radial-gradient(circle,rgba(255,210,74,.5),transparent 65%);top:-80px;right:-40px}
.phero .b2{width:300px;height:300px;background:radial-gradient(circle,rgba(63,158,208,.32),transparent 65%);bottom:-120px;left:-60px}
.phero .wrap{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--yellow-deep);border-radius:2px}
.phero h1{font-size:clamp(2.3rem,5.4vw,3.7rem);line-height:1.08;color:var(--green-darker);font-weight:700;margin:16px 0 16px;max-width:18ch}
.phero p{color:var(--muted);font-size:1.08rem;line-height:1.7;max-width:60ch}
.hchips{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px}
.hchip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:.84rem;font-weight:600;color:var(--green-darker)}
.hchip::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c,var(--green))}
/* SECTION HEADERS */
  .pad{padding:64px 0;position:relative;z-index:1}
.shead{text-align:center;max-width:62ch;margin:0 auto 46px}
.shead h2{font-size:clamp(1.8rem,3.8vw,2.6rem);color:var(--green-darker);font-weight:700;line-height:1.14;margin:14px 0 12px}
.shead p{color:var(--muted);line-height:1.7}
/* SERVICES GRID */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.scard{position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 26px 28px;overflow:hidden;
     box-shadow:0 30px 60px -50px rgba(18,46,35,.5);transition:transform .3s var(--ease),box-shadow .3s;opacity:0;transform:translateY(26px)}
.scard.in{opacity:1;transform:none}
.scard:hover{transform:translateY(-6px);box-shadow:0 48px 80px -46px rgba(18,46,35,.5)}
.scard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--c,var(--green))}
.s-ico{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px;
     background:color-mix(in srgb,var(--c,var(--green)) 14%,#fff);}
.s-ico svg{width:28px;height:28px;color:var(--c,var(--green));stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.scard h3{font-family:var(--font-display);font-size:1.18rem;color:var(--green-darker);font-weight:700;margin-bottom:8px}
.scard p{color:var(--muted);font-size:.92rem;line-height:1.62}
.s-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.s-tags span{font-size:.72rem;font-weight:600;color:var(--green-darker);background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:4px 10px}
/* PROCESS / DESIGN THINKING */
  .process{background:linear-gradient(180deg,#eef7f1,#f7fcf9);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.date-row{display:flex;justify-content:center;gap:10px;margin:-12px 0 40px}
.date-chip{background:#fff;border:1px solid var(--line);border-radius:14px;padding:11px 18px;font-weight:600;font-size:.85rem;color:var(--muted)}
.date-chip.on{background:var(--leaf);color:#fff;border-color:transparent;box-shadow:0 14px 28px -16px rgba(76,180,145,.9)}
.date-chip small{display:block;font-size:.66rem;font-weight:500;opacity:.8;letter-spacing:.04em;text-transform:uppercase}
.tl{position:relative;max-width:900px;margin:0 auto;padding:8px 0}
.tl::before{content:"";position:absolute;left:50%;top:8px;bottom:8px;border-left:2px dashed #bcdccd;transform:translateX(-1px)}
.pstep{position:relative;width:calc(50% - 48px);margin-bottom:30px;opacity:0;transform:translateY(26px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.pstep.in{opacity:1;transform:none}
.pstep:nth-child(even){margin-left:auto}
/* node on the centre line */
  .pstep .node{position:absolute;top:30px;width:18px;height:18px;border-radius:50%;background:var(--c,var(--green));border:4px solid #fff;box-shadow:0 0 0 2px var(--c,var(--green)),0 8px 16px -6px rgba(0,0,0,.3);z-index:3}
.pstep:nth-child(odd) .node{right:-57px}
.pstep:nth-child(even) .node{left:-57px}
/* dashed connector from card to centre */
  .pstep .conn{position:absolute;top:38px;height:0;border-top:2px dashed #bcdccd;z-index:1}
.pstep:nth-child(odd) .conn{right:-48px;width:48px}
.pstep:nth-child(even) .conn{left:-48px;width:48px}
.pbox{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:14px;box-shadow:0 30px 60px -50px rgba(18,46,35,.55)}
.pdur{flex:0 0 auto;width:38px;border-radius:14px;background:var(--green-darker);color:#fff;display:flex;align-items:center;justify-content:center;padding:14px 0}
.pdur.dark{background:#1b2622}
.pdur span{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.pbody{flex:1;min-width:0;padding:4px 6px 6px 0}
.prow{display:flex;align-items:center;gap:11px;margin-bottom:9px}
.picon{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:0 0 auto;background:color-mix(in srgb,var(--c,var(--green)) 15%,#fff)}
.picon svg{width:21px;height:21px;stroke:var(--c,var(--green));fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ptitle{font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--green-darker);line-height:1.2}
.ptitle b{color:var(--c,var(--leaf));font-weight:700;margin-right:2px}
.pdesc{color:var(--muted);font-size:.9rem;line-height:1.6}
/* CTA band */
  .ctaband{margin:34px 0 80px}
.ctaband .inner{position:relative;overflow:hidden;border-radius:30px;padding:54px 48px;text-align:center;
     background:linear-gradient(135deg,var(--green-deep),var(--green));box-shadow:0 50px 90px -50px rgba(18,46,35,.7)}
.ctaband .inner::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,74,.4),transparent 65%);top:-100px;right:-40px}
.ctaband .inner::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(124,198,232,.35),transparent 65%);bottom:-120px;left:-30px}
.ctaband h2{position:relative;z-index:1;color:#fff;font-size:clamp(1.7rem,3.6vw,2.5rem);font-weight:700;margin-bottom:12px}
.ctaband h2 .serif{color:var(--yellow)}
.ctaband p{position:relative;z-index:1;color:rgba(255,255,255,.86);max-width:54ch;margin:0 auto 26px;line-height:1.6}
.ctaband .btn{position:relative;z-index:1;display:inline-flex;align-items:center;gap:10px;background:var(--btn-yellow);color:var(--green-darker);font-weight:700;padding:15px 30px;border-radius:999px;font-size:1rem;box-shadow:0 18px 36px -16px rgba(0,0,0,.4)}
.ctaband .btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* FOOTER */
  .foot{background:var(--green-darker);color:#cfe6da;padding:60px 0 28px}
@media(max-width:980px){
.svc-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
/* timeline collapses to single column */
    .tl::before{left:21px}
.pstep,.pstep:nth-child(even){width:100%;margin-left:0;padding-left:54px}
.pstep .node,.pstep:nth-child(odd) .node,.pstep:nth-child(even) .node{left:12px;right:auto}
.pstep .conn,.pstep:nth-child(odd) .conn,.pstep:nth-child(even) .conn{left:30px;right:auto;width:24px}
}
@media(max-width:560px){
.svc-grid,.foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
.scard,.pstep{opacity:1;transform:none}
}
