/* JP Associates — Brand CSS v3 (JP Brand Colour Spec applied) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'DM Sans',sans-serif;color:#2D3748;background:#FAFAF8;overflow-x:hidden;width:100%;max-width:100vw}
img{display:block;max-width:100%}
a{text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── BRAND TOKENS (JP Associates Official Spec) ── */
:root{
  --jp-indigo-dark:  #0F2347;
  --jp-indigo:       #1B3A6B;
  --jp-indigo-mid:   #3460A0;
  --jp-indigo-tint:  #D6E3F5;
  --jp-saffron:      #E8890C;
  --jp-saffron-dark: #C56B00;
  --jp-saffron-tint: #FDEAC8;
  --jp-teal:         #0A7A72;
  --jp-teal-dark:    #065550;
  --jp-teal-tint:    #C2EBE8;
  --jp-charcoal:     #2D3748;
  --jp-slate:        #6B7A99;
  --jp-warm-white:   #EAE9E5;
  --jp-off-white:    #FAFAF8;
  --jp-white:        #FFFFFF;
  --jp-border:       #D8D6D0;
  /* Layout */
  --r:8px; --rl:12px; --nh:72px;
  --sh:0 2px 16px rgba(27,58,107,.10);
  --shl:0 8px 40px rgba(27,58,107,.16);
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5{font-family:'Syne',sans-serif;line-height:1.15;color:var(--jp-indigo)}
p{line-height:1.75;color:var(--jp-charcoal)}
.dxl{font-size:clamp(1.4rem,5.5vw,4.4rem);font-weight:800;letter-spacing:-.02em;line-height:1.08;overflow-wrap:break-word}
.dlg{font-size:clamp(2rem,4vw,3.2rem);font-weight:700;letter-spacing:-.018em}
.dmd{font-size:clamp(1.7rem,3vw,2.5rem);font-weight:700;letter-spacing:-.015em}
.dsm{font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:700;letter-spacing:-.01em}
/* Label/eyebrow — indigo on light, saffron on dark */
.lbl{font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--jp-indigo)}
.lbl-s{font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--jp-saffron)}
/* Saffron accent rule — the brand's section divider signal */
.rule{width:44px;height:3px;background:var(--jp-saffron);border-radius:2px;margin-top:18px}
.blg{font-size:1.05rem;line-height:1.78;color:var(--jp-slate)}
.bmd{font-size:.95rem;line-height:1.7;color:var(--jp-slate)}

/* ── DARK SECTION UTILS ── */
.dark{background:var(--jp-indigo-dark)}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.dark p{color:rgba(255,255,255,.82)}
.dark .rule{background:var(--jp-saffron)}
.dark .lbl{color:var(--jp-saffron)} /* saffron label on dark per spec */
.dark .blg,.dark .bmd{color:rgba(255,255,255,.78)}
.indigo-bg{background:var(--jp-indigo)} /* mid-dark sections */
.indigo-bg h1,.indigo-bg h2,.indigo-bg h3{color:#fff}
.indigo-bg p{color:rgba(255,255,255,.82)}
.tint-bg{background:var(--jp-indigo-tint)} /* indigo-tint sections */
.tint-bg h1,.tint-bg h2,.tint-bg h3{color:var(--jp-indigo-dark)}
.off-bg{background:var(--jp-off-white)}
.warm-bg{background:var(--jp-warm-white)}

/* ── LAYOUT ── */
section{padding:96px 5%}.si{max-width:1160px;margin:0 auto}.sh{margin-bottom:52px}
.center{text-align:center}.center .rule{margin:18px auto 0}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ── BUTTONS (JP Brand Spec §3.5) ── */
/* Primary CTA — Saffron */
.bp{display:inline-flex;align-items:center;gap:8px;background:var(--jp-saffron);color:var(--jp-indigo-dark);padding:12px 28px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:500;font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;transition:background .2s,transform .15s,box-shadow .15s;flex-shrink:0}
.bp:hover{background:var(--jp-saffron-dark);transform:translateY(-2px)}
.bp:active{transform:scale(.98)}
/* Ghost — on dark backgrounds */
.bow{display:inline-flex;align-items:center;gap:8px;color:#fff;padding:12px 28px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:500;font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;border:1.5px solid #fff;transition:background .2s,transform .15s;flex-shrink:0}
.bow:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}
/* Secondary — on light backgrounds */
.bob{display:inline-flex;align-items:center;gap:8px;color:var(--jp-indigo);padding:12px 28px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:500;font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;border:1.5px solid var(--jp-indigo);transition:background .2s,color .2s,transform .15s}
.bob:hover{background:var(--jp-indigo-tint);color:var(--jp-indigo-dark);transform:translateY(-2px)}
/* Small CTA (in nav dropdown) — Saffron */
.bsb{display:inline-flex;align-items:center;gap:6px;background:var(--jp-saffron);color:var(--jp-indigo-dark);padding:8px 18px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;transition:background .2s}
.bsb:hover{background:var(--jp-saffron-dark)}
/* Text link button */
.btxt{display:inline-flex;align-items:center;gap:6px;color:var(--jp-indigo-mid);font-weight:600;font-size:.88rem;transition:gap .2s,color .2s}
.btxt:hover{gap:10px;color:var(--jp-saffron)}

/* ── NAVIGATION (JP Brand Spec §3.1) ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;
    background:var(--jp-indigo); /* always JP Indigo per spec */
    display:flex;align-items:center;justify-content:space-between;
    padding:0 5%;height:var(--nh);
    box-shadow:0 1px 0 rgba(255,255,255,.08);
    transition:background .35s,box-shadow .35s}
nav.scrolled{background:rgba(27,58,107,.98);backdrop-filter:blur(12px);box-shadow:0 2px 28px rgba(15,35,71,.35)}
/* On inner pages the nav is always jp-indigo (already set), so .inner is same */
nav.inner{background:var(--jp-indigo)}
@media(max-width:1060px){nav{background:var(--jp-indigo-dark)!important}} /* mobile: darker per spec */
.nlogo img{height:40px;display:block;}
.nc{flex:1;display:flex;justify-content:center}
.nl{display:flex;align-items:center;gap:.1rem}
.nl>li{position:relative}
.nl>li>a{display:flex;align-items:center;gap:4px;color:rgba(255,255,255,.85);font-family:'DM Sans',sans-serif;font-weight:500;font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;padding:8px 10px;border-radius:4px;transition:color .2s,background .2s}
/* Hover → Saffron per spec */
.nl>li>a:hover{color:var(--jp-saffron);background:rgba(232,137,12,.08)}
/* Active link → Saffron with bottom border per spec */
.nl>li>a.act{color:var(--jp-saffron);border-bottom:3px solid var(--jp-saffron);border-radius:0;padding-bottom:5px}
.hd>a::after{content:'▾';font-size:.6rem;opacity:.55;margin-left:2px}

/* DROPDOWN */
.dd{position:absolute;top:100%;padding-top:10px;left:50%;
    transform:translateX(-50%) translateY(-6px);
    background:var(--jp-indigo-dark); /* dark indigo per spec */
    border:1px solid rgba(255,255,255,.1);border-radius:var(--rl);
    box-shadow:0 24px 64px rgba(15,35,71,.5);
    opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .18s,transform .18s,visibility 0s .18s;min-width:200px}
.hd:hover .dd{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);transition:opacity .18s,transform .18s,visibility 0s}
.dd.mega{min-width:520px}
.ddi{padding:18px}
.ddi a{display:block;color:rgba(255,255,255,.7);padding:7px 11px;border-radius:6px;font-size:.84rem;transition:color .15s,background .15s}
.ddi a:hover{color:var(--jp-saffron);background:rgba(232,137,12,.08)} /* saffron hover per spec */
.mega .ddi{display:flex;gap:4px}
.mc{flex:1;padding:4px}
.mc a{display:block;padding:9px 12px;border-radius:8px}
.mc a strong{display:block;color:rgba(255,255,255,.9);font-size:.84rem;margin-bottom:2px}
.mc a span{font-size:.75rem;color:rgba(255,255,255,.45)}
.mc a:hover strong{color:var(--jp-saffron)}
/* dropdown column label */
.mlbl{display:block;font-size:.64rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3);padding:4px 12px 8px;margin-bottom:4px;border-bottom:1px solid rgba(255,255,255,.08)}
/* quick-contact column in mega */
.mct{background:rgba(232,137,12,.12);border:1px solid rgba(232,137,12,.2);border-radius:10px;padding:16px;width:180px;flex:0 0 180px}
.mct .mlbl{color:rgba(232,137,12,.7);border-bottom-color:rgba(232,137,12,.2)}
.mct p{color:rgba(255,255,255,.5);font-size:.78rem;line-height:1.55;margin:7px 0 14px}
/* nav right */
.nr{display:flex;align-items:center;gap:10px}
/* CTA in nav — Saffron button per spec */
.ncta{background:var(--jp-saffron);color:var(--jp-indigo-dark);padding:8px 20px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;transition:background .2s;white-space:nowrap}
.ncta:hover{background:var(--jp-saffron-dark)}
.ham{display:none;flex-direction:column;gap:5px;padding:4px}
.ham span{width:22px;height:2px;background:#fff;border-radius:2px;transition:.3s;display:block}

/* ── HERO ── */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden}
.hph{position:absolute;inset:0}.hph img{width:100%;height:100%;object-fit:cover}
/* Overlay uses jp-indigo-dark per spec for premium dark hero */
.hov{position:absolute;inset:0;background:linear-gradient(105deg,rgba(15,35,71,.94) 0%,rgba(27,58,107,.88) 55%,rgba(27,58,107,.6) 100%)}
/* Subtle grid — indigo-toned */
.hgr{position:absolute;inset:0;background-image:linear-gradient(rgba(52,96,160,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(52,96,160,.08) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 65% 70% at 30% 60%,black,transparent)}
.hc{position:relative;z-index:2;padding-left:5%;padding-right:5%;padding-top:calc(var(--nh) + 40px);padding-bottom:0;width:100%;max-width:900px;box-sizing:border-box}
/* Hero eyebrow pill — saffron-tinted per spec */
.hey{display:inline-flex;align-items:center;gap:10px;background:rgba(232,137,12,.15);border:1px solid rgba(232,137,12,.4);color:var(--jp-saffron-tint);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;padding:7px 16px;border-radius:100px;margin-bottom:26px;animation:fadeUp .5s ease both;font-family:'DM Sans',sans-serif;font-weight:600}
.hey::before{content:'';width:6px;height:6px;background:var(--jp-saffron);border-radius:50%;flex-shrink:0}
.hh1{font-family:'Syne',sans-serif;color:#fff;margin-bottom:22px;animation:fadeUp .5s .1s ease both;overflow-wrap:break-word;max-width:100%}
/* Italic accent in hero headline — saffron per spec */
.hh1 em{font-style:normal;color:var(--jp-saffron);display:block}
.hsub{color:rgba(255,255,255,.75);line-height:1.72;max-width:520px;margin-bottom:38px;animation:fadeUp .5s .2s ease both;font-size:1rem}
.hact{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .5s .3s ease both}
/* Saffron accent bar under hero headline */
.hero-rule{width:60px;height:4px;background:var(--jp-saffron);border-radius:2px;margin:0 0 24px;animation:fadeUp .5s .08s ease both}
.hscr{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.35);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;animation:fadeIn 1s .8s ease both;font-family:'DM Sans',sans-serif}
.sbar{width:1px;height:32px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:pulse 2s infinite}

/* ── PAGE HERO ── */
.phero{padding:calc(var(--nh) + 72px) 5% 80px;background:var(--jp-indigo);position:relative;overflow:hidden}
.phpht{position:absolute;inset:0}.phpht img{width:100%;height:100%;object-fit:cover;opacity:.18}
.phov{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,35,71,.97),rgba(27,58,107,.82))}
.phc{position:relative;z-index:2;max-width:1160px;margin:0 auto}
.phero h1{color:#fff;margin-bottom:16px}
.phero p{color:rgba(255,255,255,.72);font-size:1rem;max-width:560px}
.bc{display:flex;align-items:center;gap:8px;font-size:.74rem;color:rgba(255,255,255,.42);margin-bottom:20px;font-family:'DM Sans',sans-serif;flex-wrap:wrap}
.bc a{color:rgba(255,255,255,.55)}.bc a:hover{color:var(--jp-saffron)}.bc s{color:rgba(255,255,255,.28)}

/* ── STATS BAR (JP Brand Spec §3.8 — numbers in saffron on indigo bg) ── */
.stbar{background:var(--jp-indigo);padding:48px 5%;border-top:3px solid var(--jp-teal)} /* teal top accent */
.stgr{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.st{padding:18px;border-right:1px solid rgba(255,255,255,.15)}.st:last-child{border-right:none}
/* Numbers in SAFFRON per spec §3.8 */
.stn{font-family:'Syne',sans-serif;font-weight:800;font-size:2.8rem;color:var(--jp-saffron);line-height:1;letter-spacing:-.02em}
.stl{color:#fff;font-size:.76rem;margin-top:8px;text-transform:uppercase;letter-spacing:.06em;line-height:1.4;font-family:'DM Sans',sans-serif}
.stl-main{color:#fff;font-family:'Syne',sans-serif;font-weight:700;font-size:1.05rem;margin-top:6px;line-height:1}

/* ── TICKER ── */
.tkwrap{background:var(--jp-indigo-dark);padding:14px 0;overflow:hidden;border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);max-width:100%;width:100%}
.tk{display:flex;animation:ticker 35s linear infinite;width:max-content}
.tk:hover{animation-play-state:paused}
.tki{display:inline-flex;align-items:center;gap:24px;padding:0 28px;color:rgba(255,255,255,.42);font-size:.73rem;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;font-family:'DM Sans',sans-serif}
/* Ticker dots — saffron accent */
.tkd{width:4px;height:4px;background:var(--jp-saffron);border-radius:50%;flex-shrink:0}

/* ── CARDS (JP Brand Spec §3.4) ── */
.card{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh);transition:transform .25s,box-shadow .25s,border-color .25s}
/* Hover: border changes to jp-indigo, top bar appears */
.card:hover{transform:translateY(-5px);box-shadow:var(--shl);border-color:var(--jp-indigo)}
.cdk{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--rl);padding:28px;transition:background .2s,border-color .2s}
.cdk:hover{background:rgba(255,255,255,.1);border-color:rgba(232,137,12,.3)}
.ci{height:210px;overflow:hidden;position:relative}
.ci img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .ci img{transform:scale(1.05)}
.ciov{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(15,35,71,.72))}
/* Service badge — saffron-tint per spec */
.ctag{position:absolute;top:14px;left:14px;background:var(--jp-saffron-tint);color:var(--jp-saffron-dark);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:20px}
.cb{padding:24px}
.cb h3{font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;color:var(--jp-indigo);margin-bottom:9px}
.cb p{font-size:.87rem;color:var(--jp-charcoal);line-height:1.65;margin-bottom:16px}
/* Hover accent bar on card top */
.card::before{content:'';display:block;height:0;background:var(--jp-saffron);transition:height .25s}
.card:hover::before{height:4px}
.sl{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:20px}
.sl li{display:flex;align-items:flex-start;gap:9px;font-size:.85rem;color:var(--jp-slate);line-height:1.4}
.sl li::before{content:'';width:5px;height:5px;background:var(--jp-saffron);border-radius:50%;flex-shrink:0;margin-top:6px}

/* ── ICON BOXES (§3.4 service colour mapping) ── */
.ib{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);padding:26px 22px;transition:border-color .2s,box-shadow .2s}
.ib:hover{border-color:var(--jp-indigo);box-shadow:var(--sh)}
/* Default icon bg: saffron-tint, icon: saffron-dark */
.ibw{width:50px;height:50px;background:var(--jp-saffron-tint);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ibw svg{color:var(--jp-saffron-dark)}
.ib h4{font-family:'Syne',sans-serif;font-size:.98rem;font-weight:700;color:var(--jp-indigo);margin-bottom:7px}
.ib p{font-size:.85rem;color:var(--jp-slate);line-height:1.62}
/* Teal variant for tech icon boxes */
.ib.teal .ibw{background:var(--jp-teal-tint)}
.ib.teal .ibw svg{color:var(--jp-teal-dark)}
.ib.teal h4{color:var(--jp-teal-dark)}
/* Indigo variant */
.ib.indigo .ibw{background:var(--jp-indigo-tint)}
.ib.indigo .ibw svg{color:var(--jp-indigo-dark)}


/* Industry tiles on homepage */
.ind-tile{transition:transform .3s}
.ind-tile:hover img{transform:scale(1.05)}
.ind-tile p{font-size:.95rem;line-height:1.25}

/* ── MAP SECTION ── */
.mapsc{background:var(--jp-indigo-dark);padding:96px 5%}
.mapi{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:72px;align-items:center}
.maplocs{display:flex;flex-direction:column;gap:10px;margin-top:26px}
.maploc{display:flex;align-items:center;gap:12px;padding:11px 15px;background:rgba(255,255,255,.05);border-radius:var(--r);border:1px solid rgba(255,255,255,.08);transition:border-color .2s,background .2s}
.maploc:hover{background:rgba(232,137,12,.08);border-color:rgba(232,137,12,.2)}
/* Location dot — saffron glow */
.locdt{width:8px;height:8px;background:var(--jp-saffron);border-radius:50%;flex-shrink:0;box-shadow:0 0 8px rgba(232,137,12,.6)}
.locnm{font-family:'DM Sans',sans-serif;font-size:.86rem;color:rgba(255,255,255,.8);font-weight:500}
.locsub{font-size:.73rem;color:rgba(255,255,255,.38);margin-left:auto}

/* ── CTA BAND ── */
/* CTA band uses jp-saffron bg for maximum impact */
.ctabd{background:var(--jp-indigo);padding:80px 5%;text-align:center;border-top:3px solid var(--jp-saffron)}
.ctabd h2{color:#fff;margin-bottom:14px}
.ctabd p{color:rgba(255,255,255,.78);max-width:500px;margin:0 auto 32px;font-size:1rem}
.ctabtns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── CHAUFFHER BAND ── */
.chbd{background:var(--jp-indigo-dark);overflow:hidden;border-top:3px solid var(--jp-teal)}
.chi{max-width:100%;display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.chc{padding:72px 56px 72px 5%;display:flex;flex-direction:column;justify-content:center;max-width:640px}
.chim{position:relative;overflow:hidden}.chim img{width:100%;height:100%;object-fit:cover}
.chtm{font-family:'Syne',sans-serif;font-weight:800;font-size:2.6rem;color:#fff;line-height:1;margin:10px 0 7px}
.chsub{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--jp-saffron);font-family:'DM Sans',sans-serif;font-weight:600;margin-bottom:16px}
.chdesc{color:rgba(255,255,255,.75);line-height:1.75;margin-bottom:26px;font-size:.96rem}
.chpills{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:26px}
.chp{background:rgba(232,137,12,.15);border:1px solid rgba(232,137,12,.3);color:var(--jp-saffron-tint);padding:5px 12px;border-radius:100px;font-size:.74rem;font-family:'DM Sans',sans-serif}
.chsts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08);border-radius:var(--r);overflow:hidden}
.chst{background:rgba(15,35,71,.55);padding:14px 16px}
/* Stats numbers in saffron per spec */
.chst .n{font-family:'Syne',sans-serif;font-weight:800;font-size:1.7rem;color:var(--jp-saffron)}
.chst .l{font-size:.72rem;color:rgba(255,255,255,.45);margin-top:3px;line-height:1.4}

/* ── TESTIMONIALS (§3.9) ── */
.tcard{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);padding:32px;box-shadow:var(--sh);position:relative}
/* Quote mark in saffron per spec */
.qm{font-family:Georgia,serif;font-size:4.5rem;color:var(--jp-saffron);line-height:0;position:absolute;top:22px;left:22px;opacity:.25}
.ttext{font-size:.95rem;color:var(--jp-charcoal);line-height:1.75;margin-bottom:20px;font-style:italic;padding-top:14px}
.tauth{display:flex;align-items:center;gap:11px}
/* Avatar — indigo bg */
.tav{width:40px;height:40px;border-radius:50%;background:var(--jp-indigo);color:#fff;font-family:'Syne',sans-serif;font-weight:700;font-size:.88rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* Client name in indigo per spec */
.taname{font-family:'Syne',sans-serif;font-weight:500;font-size:.9rem;color:var(--jp-indigo)}
.tarole{font-size:.74rem;color:var(--jp-slate)}

/* ── TIMELINE ── */
.tl{position:relative;padding-left:26px}
.tl::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--jp-border)}
.tli{position:relative;margin-bottom:30px}
/* Timeline dot — saffron accent */
.tld{position:absolute;left:-26px;top:4px;width:14px;height:14px;background:var(--jp-saffron);border-radius:50%;border:3px solid var(--jp-off-white);box-shadow:0 0 0 2px var(--jp-saffron)}
.tly{font-family:'Syne',sans-serif;font-size:.76rem;font-weight:700;color:var(--jp-saffron);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.tltt{font-family:'Syne',sans-serif;font-size:.98rem;font-weight:700;color:var(--jp-indigo);margin-bottom:4px}
.tldesc{font-size:.87rem;color:var(--jp-slate);line-height:1.65}

/* ── TEAM ── */
.team-card{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh);text-align:center}
.tph{height:220px;background:var(--jp-indigo-tint);display:flex;align-items:center;justify-content:center}
.tph-pl{width:86px;height:86px;border-radius:50%;background:var(--jp-indigo);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:700;font-size:1.7rem;color:#fff}
.tinfo{padding:20px 16px}
.tname{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;color:var(--jp-indigo);margin-bottom:4px}
.ttitle{font-size:.74rem;color:var(--jp-saffron);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:9px}
.tbio{font-size:.82rem;color:var(--jp-slate);line-height:1.6}

/* ── OFFICES ── */
.offc{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);padding:20px;border-left:4px solid var(--jp-saffron)}
.offc h4{font-family:'Syne',sans-serif;font-size:.84rem;font-weight:700;color:var(--jp-indigo);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.offc p{font-size:.85rem;color:var(--jp-slate);line-height:1.6;overflow-wrap:break-word;word-break:break-word}

/* ── CONTACT FORM ── */
.fgr{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.full{grid-column:1/-1}
.fg label{font-size:.71rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--jp-charcoal)}
.fg input,.fg select,.fg textarea{padding:12px 15px;border:1.5px solid var(--jp-border);border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:.92rem;color:var(--jp-charcoal);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--jp-indigo);box-shadow:0 0 0 3px rgba(27,58,107,.1)}
.fg textarea{height:130px;resize:vertical}
.fbtn{width:100%;background:var(--jp-saffron);color:var(--jp-indigo-dark);border:none;padding:14px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s;margin-top:6px}
.fbtn:hover{background:var(--jp-saffron-dark);transform:translateY(-2px)}
.fbtn:active{transform:scale(.98)}
.fok{display:none;background:var(--jp-teal-tint);border:1px solid var(--jp-teal);color:var(--jp-teal-dark);padding:13px 16px;border-radius:var(--r);font-size:.88rem;margin-top:10px;text-align:center}

/* ── CINFO ── */
.cinfo{display:flex;align-items:flex-start;gap:13px;margin-bottom:17px}
.cion{width:38px;height:38px;background:var(--jp-indigo-tint);border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--jp-indigo);flex-shrink:0}
.cit strong{display:block;font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--jp-indigo);margin-bottom:2px}
.cit span,.cit a{font-size:.87rem;color:var(--jp-slate)}

/* ── SERVICE DETAIL ── */
.svc-detail-list{list-style:none;display:flex;flex-direction:column;gap:0}
.svc-detail-item{padding:22px 0;border-bottom:1px solid var(--jp-border);display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.svc-detail-item:last-child{border-bottom:none}
.svc-icon-box{width:44px;height:44px;background:var(--jp-saffron-tint);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-icon-box svg{color:var(--jp-saffron-dark)}
.svc-detail-item h4{font-family:'Syne',sans-serif;font-size:.97rem;font-weight:700;color:var(--jp-indigo);margin-bottom:5px}
.svc-detail-item p{font-size:.86rem;color:var(--jp-slate);line-height:1.65}

/* ── WHY JP ── */
.why-item{display:flex;gap:18px;align-items:flex-start;padding:22px;background:var(--jp-off-white);border:0.5px solid var(--jp-border);border-radius:var(--rl)}
.why-num{font-family:'Syne',sans-serif;font-weight:800;font-size:2.2rem;color:var(--jp-saffron);line-height:1;flex-shrink:0;opacity:.35}
.why-item h4{font-family:'Syne',sans-serif;font-size:.97rem;font-weight:700;color:var(--jp-indigo);margin-bottom:5px}
.why-item p{font-size:.85rem;color:var(--jp-slate);line-height:1.6}

/* ── CAREERS ── */
.job-card{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:var(--sh);transition:border-color .2s,box-shadow .2s}
.job-card:hover{border-color:var(--jp-saffron);box-shadow:var(--shl)}
.job-title{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;color:var(--jp-indigo);margin-bottom:6px}
.job-meta{display:flex;gap:10px;flex-wrap:wrap}
.job-tag{font-size:.72rem;color:var(--jp-slate);background:var(--jp-warm-white);padding:4px 9px;border-radius:4px}

/* ── ESG ── */
.esg-card{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);padding:32px;box-shadow:var(--sh);border-top:4px solid var(--jp-saffron)}
.esg-icon{width:52px;height:52px;border-radius:12px;background:var(--jp-saffron-tint);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.esg-icon svg{color:var(--jp-saffron-dark)}
.esg-card h3{font-family:'Syne',sans-serif;font-size:1.15rem;font-weight:700;color:var(--jp-indigo);margin-bottom:11px}
.esg-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.esg-list li{font-size:.86rem;color:var(--jp-slate);line-height:1.5;display:flex;gap:7px;align-items:flex-start}
.esg-list li::before{content:'✓';color:var(--jp-teal);font-weight:700;flex-shrink:0}

/* ── NEWS ── */
.news-card{background:#fff;border:0.5px solid var(--jp-border);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s}
.news-card:hover{box-shadow:var(--shl);transform:translateY(-4px)}
.news-img{height:180px;background:var(--jp-indigo-tint);display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.news-body{padding:22px}
.news-date{font-size:.72rem;color:var(--jp-saffron);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.news-title{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;color:var(--jp-indigo);margin-bottom:9px;line-height:1.3}
.news-desc{font-size:.84rem;color:var(--jp-slate);line-height:1.62}
.article-full{display:none;margin-top:12px;font-size:.84rem;color:var(--jp-slate);line-height:1.7;border-top:1px solid var(--jp-border);padding-top:12px}
.article-full.open{display:block}
.read-more-btn{display:inline-flex;align-items:center;gap:5px;color:var(--jp-indigo-mid);font-weight:600;font-size:.86rem;margin-top:12px;cursor:pointer;background:none;border:none;font-family:'DM Sans',sans-serif;padding:0;transition:gap .2s,color .2s}
.read-more-btn:hover{gap:9px;color:var(--jp-saffron)}

/* ── FOOTER (§3.10) ── */
footer{background:var(--jp-indigo-dark);padding:0;border-top:3px solid var(--jp-teal)} /* teal top accent per spec */
.footer-inner{padding:68px 5% 30px}
.ftp{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:28px}
.flogo img{height:40px;margin-bottom:16px}
.fdesc{font-size:.86rem;color:rgba(255,255,255,.5);line-height:1.7;max-width:250px;margin-bottom:20px}
.fci{display:flex;align-items:flex-start;gap:9px;font-size:.83rem;color:rgba(255,255,255,.5);margin-bottom:9px;line-height:1.5}
.fci svg{flex-shrink:0;margin-top:2px;color:var(--jp-saffron)} /* saffron icons in footer */
/* Footer column headings — SAFFRON per spec §3.10 */
.fc h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--jp-saffron);margin-bottom:16px}
.fc ul{display:flex;flex-direction:column;gap:8px}
.fc ul a{color:rgba(255,255,255,.55);font-size:.85rem;transition:color .2s}
.fc ul a:hover{color:var(--jp-saffron)} /* saffron on hover per spec */
.fbt{max-width:1160px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:.76rem;color:rgba(255,255,255,.28);flex-wrap:wrap;gap:8px}
.fbt a{color:rgba(255,255,255,.35)}.fbt a:hover{color:var(--jp-saffron)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.8}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── RESPONSIVE ── */
@media(max-width:1060px){
  nav{background:var(--jp-indigo-dark)!important}
  .nc{display:none}
  .nc.open{display:block;position:fixed;top:var(--nh);left:0;right:0;bottom:0;background:var(--jp-indigo-dark);padding:16px 5% 32px;border-top:1px solid rgba(232,137,12,.2);box-shadow:0 16px 32px rgba(15,35,71,.5);overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:999}
  .nc.open .nl{display:flex;flex-direction:column;align-items:flex-start;width:100%;gap:0}
  .nl>li>a{padding:12px 0;border-radius:0;border-bottom:1px solid rgba(255,255,255,.07);width:100%}
  .nl>li>a.act{border-bottom-color:var(--jp-saffron);border-bottom-width:2px}
  .hd>a::after{display:none}
  .dd{position:static!important;transform:none!important;opacity:1!important;visibility:visible!important;pointer-events:auto;background:transparent;border:none;box-shadow:none;min-width:0!important;max-width:none;padding-top:0}
  .dd.mega{min-width:0!important}
  .ddi,.mega .ddi{flex-direction:column;padding:0 0 0 14px}
  .mc,.mct{width:auto;max-width:none;flex:none;background:transparent;border:none}
  .mct .bsb{display:none}
  .ham{display:flex}
  .g3{grid-template-columns:repeat(2,1fr)}
  .g4{grid-template-columns:repeat(2,1fr)}
  .stgr{grid-template-columns:repeat(2,1fr)}
  .st{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .st:nth-child(odd){border-right:1px solid rgba(255,255,255,.12)}
  .ftp{grid-template-columns:1fr 1fr;gap:32px}
  .mapi{grid-template-columns:1fr;gap:44px}
}
@media(max-width:768px){
  section{padding:64px 5%}
  .g2{grid-template-columns:1fr;gap:36px}
  .g3.ind-grid{grid-template-columns:1fr 1fr}
  .ind-tile p{font-size:.85rem}
  .ind-tile{height:200px!important}
  .chi{grid-template-columns:1fr;min-height:auto}
  .chim{height:260px;order:2}
  .chc{padding:48px 5%;order:1;max-width:100%}
  .chtm{font-size:2rem}
  .ftp{grid-template-columns:1fr}
  .fgr{grid-template-columns:1fr}
  .fg.full{grid-column:1}
  .hact{flex-direction:column;align-items:flex-start}
  .ctabtns{flex-direction:column;align-items:center}
  .job-card{flex-direction:column;align-items:flex-start}
  .svc-detail-item{grid-template-columns:1fr;gap:10px}
  .svc-icon-box{display:none}
  .phero{padding:calc(var(--nh) + 48px) 5% 60px}
  .why-item{flex-direction:column;gap:10px}
  .why-num{font-size:1.8rem}
}
@media(max-width:480px){
  .g3,.g4{grid-template-columns:1fr}
  .g3.ind-grid{grid-template-columns:1fr 1fr}
  .ind-tile{height:180px!important}
  .stgr{grid-template-columns:1fr}
  .st{border-right:none}
  .chsts{grid-template-columns:1fr}
  .dxl{font-size:clamp(1.3rem,7vw,1.9rem);letter-spacing:-.01em}
  .dlg{font-size:1.9rem}
  .dmd{font-size:1.6rem}
  .stn{font-size:2.2rem}
  .nlogo img{height:32px}
  .hact .bp,.hact .bow{width:100%;justify-content:center}
  section{padding:52px 4%}
  .phero{padding:calc(var(--nh) + 36px) 4% 48px}
}

/* Mid-page split sections */
.mid-split{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;min-height:420px}
.mid-split>div{min-height:320px}
@media(max-width:768px){
  .mid-split{grid-template-columns:1fr}
  .mid-split>div:first-child{min-height:240px}
}
/* Team photo strip */
.team-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;height:280px;overflow:hidden;border-radius:var(--rl);margin-bottom:48px}
.team-strip>div{overflow:hidden;position:relative}
.team-strip img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.team-strip>div:hover img{transform:scale(1.06)}
@media(max-width:768px){.team-strip{height:200px;grid-template-columns:1fr 1fr}.team-strip>div:last-child{display:none}}