/* Service sub-pages shared styles */
:root{--section-pad:6rem 7%}

.hero-svc{
  padding:7.25rem 7% 4.5rem;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:3rem;
  align-items:center;
  min-height:52vh;
  position:relative;
  overflow:hidden;
}
.hero-svc::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--border),transparent);
}
.hero-svc .hero-glow{
  position:absolute;
  width:720px;height:440px;
  background:radial-gradient(ellipse,oklch(60% 0.20 200 / 0.16) 0%,transparent 70%);
  top:55%;left:28%;transform:translate(-50%,-50%);
  pointer-events:none;z-index:0;
}
.hero-svc .hero-left{position:relative;z-index:1}
.hero-svc .hero-right{position:relative;z-index:1}

.svc-breadcrumb{
  font-family:var(--font-mono);
  font-size:.68rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--gray);
  margin-bottom:1rem;
  display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;
}
.svc-breadcrumb a{color:var(--gray);text-decoration:none}
.svc-breadcrumb a:hover{color:var(--white)}
.svc-breadcrumb .sep{opacity:.55}

.hero-svc h1{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,4.2rem);
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.04;
  margin-bottom:1.1rem;
}
.hero-svc .hero-sub{
  font-size:1.05rem;
  color:var(--gray);
  max-width:560px;
  line-height:1.7;
  margin-bottom:1.9rem;
}

.hero-metrics{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.9rem;
}
.metric{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:1.1rem 1.2rem;
  backdrop-filter:blur(16px);
  transition:transform .25s,border-color .25s;
}
.metric:hover{transform:translateY(-2px);border-color:oklch(78% 0.20 200 / 0.35)}
.metric .k{
  font-family:var(--font-display);
  font-size:1.45rem;
  font-weight:800;
  line-height:1;
  margin-bottom:.25rem;
}
.metric .l{
  font-family:var(--font-mono);
  font-size:.6rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--gray);
}

.svc-section{padding:var(--section-pad);position:relative}
.svc-section.alt{background:var(--bg2)}
.svc-section .section-label{
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:1.1rem;
  display:flex;align-items:center;gap:.55rem;
}
.svc-section .section-label::before{content:'';display:inline-block;width:18px;height:1px;background:var(--cyan)}
.svc-section h2{
  font-family:var(--font-display);
  font-size:clamp(1.7rem,3vw,2.5rem);
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.12;
  margin-bottom:1rem;
}
.svc-section .section-sub{
  color:var(--gray);
  max-width:760px;
  line-height:1.75;
  margin-bottom:2.2rem;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1.2rem;
}
.card{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:1.55rem;
  backdrop-filter:blur(16px);
  transition:transform .25s,border-color .25s;
}
.card:hover{transform:translateY(-2px);border-color:oklch(78% 0.20 200 / 0.35)}
.card .t{
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:-0.01em;
  margin-bottom:.55rem;
}
.card p{color:var(--gray);font-size:.92rem;line-height:1.7;margin:0}

.list{
  display:flex;
  flex-direction:column;
  gap:.65rem;
}
.li{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  border-bottom:1px solid oklch(30% 0.03 240 / 0.25);
  padding:.55rem 0;
}
.li:last-child{border-bottom:none}
.li .dot{
  width:18px;height:18px;border-radius:50%;
  flex-shrink:0;margin-top:2px;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;
  background:oklch(78% 0.20 200 / 0.12);
  color:var(--cyan);
  border:1px solid oklch(78% 0.20 200 / 0.3);
}
.li .txt{font-size:.92rem;line-height:1.65}

.stack-grid{display:flex;flex-wrap:wrap;gap:.5rem}
.stack-tag{
  font-family:var(--font-mono);
  font-size:.65rem;
  letter-spacing:.07em;
  padding:.35rem .75rem;
  border-radius:6px;
  background:var(--bg3);
  border:1px solid var(--border);
  color:var(--gray);
  display:flex;align-items:center;gap:.4rem;
  transition:border-color .2s,color .2s,transform .2s;
}
.stack-tag:hover{border-color:var(--cyan-dim);color:var(--white);transform:translateY(-1px)}
.stack-tag.primary{
  background:oklch(78% 0.20 200 / 0.08);
  border-color:oklch(78% 0.20 200 / 0.3);
  color:var(--cyan-dim);
}
.stack-tag .d{width:4px;height:4px;border-radius:50%;background:currentColor}

.cta-slim{
  padding:5.5rem 7%;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-slim::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:760px;height:420px;
  background:radial-gradient(ellipse,oklch(60% 0.20 200 / 0.14) 0%,transparent 70%);
  pointer-events:none;
}
.cta-slim h2{
  font-family:var(--font-display);
  font-size:clamp(1.9rem,4vw,2.7rem);
  font-weight:800;
  letter-spacing:-0.02em;
  margin-bottom:.85rem;
  position:relative;z-index:1;
}
.cta-slim p{
  font-size:1rem;
  color:var(--gray);
  max-width:620px;
  margin:0 auto 2.1rem;
  line-height:1.7;
  position:relative;z-index:1;
}

/* Animations */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-right{opacity:0;transform:translateX(26px);transition:opacity .7s .1s cubic-bezier(.22,1,.36,1),transform .7s .1s cubic-bezier(.22,1,.36,1)}
.reveal-right.in{opacity:1;transform:translateX(0)}
.stagger > *{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.stagger.in > *{opacity:1;transform:translateY(0)}
.stagger.in > *:nth-child(1){transition-delay:.02s}
.stagger.in > *:nth-child(2){transition-delay:.08s}
.stagger.in > *:nth-child(3){transition-delay:.14s}
.stagger.in > *:nth-child(4){transition-delay:.20s}
.stagger.in > *:nth-child(5){transition-delay:.26s}
.stagger.in > *:nth-child(6){transition-delay:.32s}

@media (max-width: 992px){
  .hero-svc{grid-template-columns:1fr;min-height:auto}
  .hero-metrics{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 768px){
  .hero-metrics{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
}
