/* ============================================================
   JCS BPO — "About Us" page styles
   Builds on style.css + ourwork.css (shared tokens, header,
   footer, hero artistic background, reveal system).
   Adds: animated orbit hero graphic, mission/vision, core
   values, story/leadership, milestone timeline, CEO message,
   culture band.
   ============================================================ */

/* ---- Hero copy tuning ---- */
.ab-hero .hero-copy{max-width:600px}
.ab-hero .hero-copy h1{font-size:clamp(2.3rem,4.6vw,4rem)}
.ab-hero .hero-copy p.sub{max-width:580px}
.ab-hero .hero-copy p.sub + p.sub{margin-top:-1.1rem;font-size:clamp(1rem,1.45vw,1.16rem);color:var(--muted)}
.ab-hero .hero-grid{grid-template-columns:1.02fr .98fr}

/* ============ Hero figure — animated orbit composition ============ */
.about-figure{position:relative;display:grid;place-items:center;min-height:clamp(420px,46vw,560px)}
.about-figure::before{
  content:"";position:absolute;inset:6%;z-index:-1;border-radius:50%;
  background:conic-gradient(from 0deg,
    color-mix(in srgb,var(--primary) 60%,transparent),
    color-mix(in srgb,var(--accent) 60%,transparent),
    color-mix(in srgb,var(--accent-2) 55%,transparent),
    color-mix(in srgb,var(--primary) 60%,transparent));
  filter:blur(54px);opacity:.5;animation:abSpin 18s linear infinite;
}
@keyframes abSpin{to{transform:rotate(360deg)}}

.orbit-stage{position:relative;width:clamp(330px,37vw,460px);aspect-ratio:1;display:grid;place-items:center}

/* concentric rings */
.orb-ring{position:absolute;border-radius:50%;border:1px dashed rgba(255,255,255,.16)}
.orb-ring-1{inset:0;animation:ringPulse 6s var(--ease) infinite}
.orb-ring-2{inset:15%;border-style:solid;border-color:rgba(255,255,255,.10)}
.orb-ring-3{inset:30%;animation:ringPulse 6s var(--ease) infinite .8s}
@keyframes ringPulse{0%,100%{opacity:.5}50%{opacity:1}}

/* glowing core */
.orbit-core{
  position:relative;width:36%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,rgba(255,255,255,.14),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);
  box-shadow:0 30px 70px -28px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.3),0 0 0 8px color-mix(in srgb,var(--primary) 12%,transparent);
  animation:coreFloat 7s var(--ease) infinite;
}
@keyframes coreFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.orbit-core .core-mark{display:flex;flex-direction:column;align-items:center;gap:.2rem;text-align:center}
.orbit-core .core-ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--grad);color:var(--on-primary);box-shadow:0 12px 26px -10px var(--halo)}
.orbit-core .core-ico svg{width:24px;height:24px}
.orbit-core b{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.05rem;color:var(--heading);letter-spacing:.02em;line-height:1}
.orbit-core span{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}

/* satellites that orbit the core */
.sat{position:absolute;top:50%;left:50%;width:0;height:0;animation:satSpin var(--dur,24s) linear infinite;animation-delay:var(--delay,0s)}
.sat .dot{
  position:absolute;transform:translate(-50%,-50%) translateY(calc(-1 * var(--r,160px)));
  display:flex;align-items:center;gap:.55rem;white-space:nowrap;
  padding:.55rem .85rem .55rem .6rem;border-radius:999px;
  background:rgba(13,42,69,.86);border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 18px 40px -20px rgba(0,0,0,.7);
  animation:satSpin var(--dur,24s) linear infinite reverse;animation-delay:var(--delay,0s);
}
.sat.r-out{--r:clamp(150px,19vw,196px)}
.sat.r-in{--r:clamp(112px,14.5vw,146px)}
.sat .dot .si{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--grad);color:var(--on-primary)}
.sat .dot .si svg{width:16px;height:16px}
.sat .dot b{font-family:"Poppins",sans-serif;font-weight:600;font-size:.82rem;color:var(--heading)}

@media (prefers-reduced-motion:reduce){
  .about-figure::before,.orbit-core,.orb-ring,.sat,.sat .dot{animation:none!important}
}

/* ============ Section 2 — Mission & Vision ============ */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,2.6vw,2rem)}
.mv-card{
  position:relative;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:clamp(2rem,3.4vw,2.9rem);overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
}
.mv-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad)}
.mv-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.mv-ico{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:var(--halo);color:var(--primary);margin-bottom:1.4rem}
.mv-ico svg{width:28px;height:28px}
.mv-card h3{font-family:"Poppins",sans-serif;font-weight:700;font-size:clamp(1.5rem,2.4vw,2rem);color:var(--heading);margin-bottom:1rem}
.mv-lead{font-size:clamp(1.06rem,1.5vw,1.22rem);color:var(--heading);font-weight:500;line-height:1.5;margin-bottom:1rem}
.mv-card p{font-size:1rem;color:var(--muted);line-height:1.62;margin:0}
.mv-card .em{color:var(--primary-strong);font-weight:700}

/* ============ Section 3 — Core Values ============ */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.value-card{
  position:relative;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:2rem 1.7rem;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
}
.value-card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s}
.value-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.value-card:hover::after{opacity:1}
.value-num{position:absolute;top:1.5rem;right:1.6rem;font-family:"Poppins",sans-serif;font-weight:700;font-size:.85rem;color:var(--border-strong)}
.value-ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;background:var(--grad);color:var(--on-primary);margin-bottom:1.3rem;box-shadow:0 12px 26px -12px var(--halo);transition:transform .5s var(--ease)}
.value-card:hover .value-ico{transform:rotate(-8deg) scale(1.06)}
.value-ico svg{width:26px;height:26px}
.value-card h4{font-family:"Poppins",sans-serif;font-weight:600;font-size:1.2rem;color:var(--heading);margin-bottom:.7rem}
.value-card p{font-size:.95rem;color:var(--muted);line-height:1.58;margin:0}

/* ============ Section 4 — Our Story & Leadership ============ */
.story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.4rem,5vw,4.5rem);align-items:center}
.story-block + .story-block{margin-top:2.4rem;padding-top:2.4rem;border-top:1px solid var(--border)}
.story-block .eyebrow{margin-bottom:1rem}
.story-block h3{font-family:"Poppins",sans-serif;font-weight:700;font-size:clamp(1.6rem,2.7vw,2.3rem);color:var(--heading);margin-bottom:1rem}
.story-block p{font-size:1.06rem;color:var(--text);line-height:1.68;margin:0}

/* team photo figure */
.team-figure{position:relative}
.team-figure .team-frame{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:14px;
  background:linear-gradient(150deg,rgba(255,255,255,.12),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 40px 92px -38px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.22);
}
.team-figure .team-img{display:block;width:100%;height:clamp(360px,40vw,500px);border-radius:18px;overflow:hidden}
.team-badge{
  position:absolute;left:-22px;bottom:30px;z-index:3;display:flex;align-items:center;gap:.8rem;
  background:rgba(13,42,69,.88);border:1px solid rgba(255,255,255,.16);border-radius:16px;
  padding:.9rem 1.1rem;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 24px 52px -22px rgba(0,0,0,.72);animation:teamBadge 6s var(--ease) infinite;
}
@keyframes teamBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.team-badge .tb-ico{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--grad);color:var(--on-primary)}
.team-badge .tb-ico svg{width:21px;height:21px}
.team-badge b{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.5rem;color:var(--heading);display:block;line-height:1}
.team-badge span{font-size:.78rem;color:var(--muted)}
@media (prefers-reduced-motion:reduce){.team-badge{animation:none!important}}

/* ============ Section 5 — Milestones & Achievements ============ */
.ms-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2.4rem,5vw,4rem);align-items:start}
.timeline{position:relative;padding-left:2.4rem;list-style:none;margin:0}
.timeline::before{content:"";position:absolute;left:11px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--primary),color-mix(in srgb,var(--primary) 20%,transparent));}
.tl-item{position:relative;padding-bottom:2rem}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-2.4rem;top:2px;width:24px;height:24px;border-radius:50%;
  background:var(--surface);border:2px solid var(--primary);box-shadow:0 0 0 5px color-mix(in srgb,var(--primary) 14%,transparent)}
.tl-item::after{content:"";position:absolute;left:calc(-2.4rem + 7px);top:9px;width:10px;height:10px;border-radius:50%;background:var(--grad)}
.tl-item h4{font-family:"Poppins",sans-serif;font-weight:600;font-size:1.12rem;color:var(--heading);margin-bottom:.3rem}
.tl-item p{font-size:.98rem;color:var(--muted);line-height:1.55;margin:0}
.tl-step{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.1em;color:var(--primary);font-weight:500;display:block;margin-bottom:.25rem}

.achieve-card{
  position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:clamp(2rem,3.4vw,2.8rem);
  background:var(--grad-deep);color:#fff;box-shadow:var(--shadow-lg);
}
.achieve-card::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 88% 8%,rgba(255,255,255,.14),transparent 58%)}
.achieve-card .ac-in{position:relative;z-index:1}
.achieve-card .ac-ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);color:#fff;margin-bottom:1.4rem}
.achieve-card .ac-ico svg{width:26px;height:26px}
.achieve-card h3{color:#fff;font-family:"Poppins",sans-serif;font-weight:700;font-size:clamp(1.4rem,2.2vw,1.8rem);margin-bottom:1rem}
.achieve-card p{color:rgba(255,255,255,.86);font-size:1.04rem;line-height:1.62;margin:0}
.achieve-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.achieve-pills span{font-family:"Poppins",sans-serif;font-weight:600;font-size:.8rem;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:.45rem .9rem;border-radius:999px}

/* ============ Section 6 — CEO Message ============ */
.ceo{background:var(--bg-alt)}
.ceo-card{
  position:relative;max-width:960px;margin-inline:auto;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(2.4rem,5vw,4rem);box-shadow:var(--shadow-md);overflow:hidden;
}
.ceo-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad)}
.ceo-qm{position:absolute;top:1.4rem;right:2.4rem;font-family:"Poppins",sans-serif;font-weight:700;font-size:7rem;line-height:.5;color:var(--accent);opacity:.14;pointer-events:none}
.ceo-card .eyebrow{margin-bottom:1.6rem}
.ceo-card blockquote{margin:0;display:flex;flex-direction:column;gap:1.1rem}
.ceo-card blockquote p{font-family:"Poppins",sans-serif;font-weight:500;font-size:clamp(1.1rem,1.9vw,1.45rem);line-height:1.5;color:var(--heading);letter-spacing:-.01em}
.ceo-card blockquote p.lead-line{font-size:clamp(1.25rem,2.3vw,1.7rem);font-weight:600}
.ceo-by{display:flex;align-items:center;gap:1.1rem;margin-top:2.2rem;padding-top:1.8rem;border-top:1px solid var(--border)}
.ceo-av{width:64px;height:64px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:var(--on-primary);font-family:"Poppins",sans-serif;font-weight:700;font-size:1.3rem;flex:none;box-shadow:0 12px 28px -12px var(--halo)}
.ceo-by b{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.15rem;color:var(--heading);display:block;line-height:1.2}
.ceo-by span{font-size:.92rem;color:var(--muted)}

/* ============ Section 7 — Culture ============ */
.culture-band{position:relative;overflow:hidden}
.culture-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.4rem,5vw,4.5rem);align-items:center}
.culture-copy h2{font-size:clamp(2rem,3.8vw,2.9rem);font-weight:700;margin:.5rem 0 1.1rem}
.culture-copy p{font-size:clamp(1.06rem,1.6vw,1.24rem);color:var(--text);line-height:1.66;margin:0}
.culture-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.cult-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.7rem 1.5rem;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
}
.cult-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.cult-card .cc-ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--halo);color:var(--primary);margin-bottom:1rem}
.cult-card .cc-ico svg{width:23px;height:23px}
.cult-card b{font-family:"Poppins",sans-serif;font-weight:600;font-size:1.08rem;color:var(--heading);display:block;margin-bottom:.35rem}
.cult-card p{font-size:.92rem;color:var(--muted);line-height:1.5;margin:0}
/* gentle column stagger via transform (no layout overlap) */
.culture-cards .cult-card:nth-child(even){transform:translateY(1.6rem)}
.culture-cards .cult-card:nth-child(even):hover{transform:translateY(calc(1.6rem - 6px))}

/* ============ Responsive ============ */
@media (max-width:1024px){
  .mv-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .story-grid{grid-template-columns:1fr}
  .ms-grid{grid-template-columns:1fr}
  .culture-grid{grid-template-columns:1fr}
  .culture-cards .cult-card:nth-child(n){margin-top:0}
}
@media (max-width:920px){
  .ab-hero .hero-grid{grid-template-columns:1fr}
  .about-figure{margin-top:1rem;min-height:auto}
}
@media (max-width:680px){
  .values-grid{grid-template-columns:1fr}
  .culture-cards{grid-template-columns:1fr}
  .culture-cards .cult-card:nth-child(even),.culture-cards .cult-card:nth-child(even):hover{transform:none}
  .team-badge{left:0}
  .orbit-stage{width:min(88vw,360px)}
  .sat .dot b{font-size:.74rem}
}
