/* ================================================================
   Service Page — Styles specific to service detail pages
   Shared styles (section.block, .lab, h2.st, .st-head, .btn, etc.)
   live in redesign.css and are NOT duplicated here.
   ================================================================ */

/* Hero — service-page overrides */
.svc-hero{padding:48px 0 120px;position:relative;overflow:hidden;isolation:isolate;border-bottom:1px solid var(--line)}
.svc-hero::before{content:'';position:absolute;inset:-30%;z-index:-2;background:
  radial-gradient(circle at 20% 30%,rgba(255,77,31,.50),transparent 45%),
  radial-gradient(circle at 80% 25%,rgba(255,184,0,.45),transparent 45%),
  radial-gradient(circle at 80% 80%,rgba(61,91,255,.50),transparent 45%),
  radial-gradient(circle at 25% 85%,rgba(232,62,140,.45),transparent 45%),
  radial-gradient(circle at 50% 50%,rgba(0,184,107,.30),transparent 50%);
  animation:aurora 22s ease-in-out infinite alternate;transform:translateZ(0)}
.svc-hero::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.9) 25%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.15) 75%,transparent 100%)}
@keyframes aurora{0%{transform:translate3d(0,0,0) rotate(0) scale(1)}50%{transform:translate3d(3%,-2%,0) rotate(-4deg) scale(1.12)}100%{transform:translate3d(2%,-3%,0) rotate(-6deg) scale(1.1)}}
@media(prefers-reduced-motion:reduce){.svc-hero::before{animation:none}}

.svc-hero .hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:end;padding-top:48px;position:relative}
.svc-hero .eye{font-family:var(--fm);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--pop-1);display:inline-flex;align-items:center;gap:10px;margin-bottom:28px}
.svc-hero .eye::before{content:'';width:28px;height:1px;background:currentColor}
.svc-hero h1{font-family:var(--fs);font-weight:400;font-size:clamp(48px,6vw,88px);line-height:1.03;letter-spacing:-.025em;margin:0 0 28px;max-width:16ch}
.svc-hero h1 em{font-style:italic;font-weight:500;background:linear-gradient(120deg,var(--pop-1),var(--pop-5) 60%,var(--pop-4));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.svc-hero .hero-lead{font-size:19px;line-height:1.55;color:var(--ink-2);max-width:52ch;margin:0 0 36px}
.svc-hero .hero-act{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}

/* Compliance badges */
.compliance{display:flex;gap:20px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line)}
.compliance .c{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:8px}
.compliance .c::before{content:'\2713';color:var(--pop-3);font-weight:700;font-size:13px}

/* Stats card */
.hstats{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:36px;box-shadow:0 40px 80px -50px rgba(0,0,0,.25)}
.hstats h4{font-family:var(--fs);font-size:22px;font-weight:500;margin:0 0 24px;letter-spacing:-.01em}
.hstats-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.hstats .st{display:flex;flex-direction:column;gap:4px;padding:16px 0;border-top:1px solid var(--line)}
.hstats .st:nth-child(-n+2){border-top:none;padding-top:0}
.hstats .st .n{font-family:var(--fs);font-size:40px;font-weight:500;line-height:1;letter-spacing:-.02em}
.hstats .st:nth-child(1) .n{color:var(--pop-1)}
.hstats .st:nth-child(2) .n{color:var(--pop-3)}
.hstats .st:nth-child(3) .n{color:var(--pop-4)}
.hstats .st:nth-child(4) .n{color:var(--pop-5)}
.hstats .st .l{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.hstats-foot{margin-top:28px;padding-top:24px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
@media(max-width:1000px){.svc-hero .hero-grid{grid-template-columns:1fr;gap:48px}}

/* Personas */
.personas{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.persona{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:32px;display:flex;flex-direction:column;gap:16px;transition:all .25s}
.persona:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(0,0,0,.15)}
.persona:nth-child(1){border-top:3px solid var(--pop-1)}
.persona:nth-child(2){border-top:3px solid var(--pop-4)}
.persona:nth-child(3){border-top:3px solid var(--pop-3)}
.persona h3{font-family:var(--fs);font-weight:500;font-size:24px;letter-spacing:-.01em;margin:0}
.persona p{color:var(--muted);font-size:15px;margin:0;flex:1}
.persona ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.persona ul li{font-size:14px;padding-left:22px;position:relative}
.persona ul li::before{content:'';position:absolute;left:0;top:7px;width:12px;height:2px;background:var(--pop-1);border-radius:2px}
.persona:nth-child(2) ul li::before{background:var(--pop-4)}
.persona:nth-child(3) ul li::before{background:var(--pop-3)}
@media(max-width:900px){.personas{grid-template-columns:1fr}}

/* Feature grid */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:8px;background:var(--paper);overflow:hidden}
.feat{padding:36px 32px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;min-height:240px;transition:background .25s;position:relative}
.feat:nth-child(3n){border-right:none}
.feat:nth-last-child(-n+3){border-bottom:none}
.feat:hover{background:var(--bg)}
.feat .fn{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-bottom:20px}
.feat h3{font-family:var(--fs);font-weight:500;font-size:22px;line-height:1.15;letter-spacing:-.015em;margin:0 0 10px}
.feat p{color:var(--muted);font-size:14px;margin:0;flex:1}
.feat .dot{width:8px;height:8px;border-radius:50%;position:absolute;top:36px;right:32px}
.feat:nth-child(1) .dot{background:var(--pop-1)}
.feat:nth-child(2) .dot{background:var(--pop-2)}
.feat:nth-child(3) .dot{background:var(--pop-3)}
.feat:nth-child(4) .dot{background:var(--pop-4)}
.feat:nth-child(5) .dot{background:var(--pop-5)}
.feat:nth-child(6) .dot{background:var(--pop-1)}
@media(max-width:900px){.feats{grid-template-columns:1fr 1fr}.feat:nth-child(3n){border-right:1px solid var(--line)}.feat:nth-child(even){border-right:none}}
@media(max-width:600px){.feats{grid-template-columns:1fr}.feat{border-right:none!important}}

/* Deliverables */
.del-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.del-col h4{font-family:var(--fs);font-weight:500;font-size:20px;margin:0 0 20px;letter-spacing:-.01em}
.del ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.del ul li{font-size:15px;padding:14px 16px 14px 44px;background:var(--paper);border:1px solid var(--line);border-radius:6px;position:relative}
.del ul li::before{content:'';position:absolute;left:16px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,var(--pop-3),var(--pop-4));box-shadow:inset 0 0 0 3px #fff}
@media(max-width:900px){.del-grid{grid-template-columns:1fr;gap:32px}}

/* Compliance strip */
.compband{background:var(--ink);color:#fff;border-radius:8px;padding:56px;position:relative;overflow:hidden;isolation:isolate}
.compband::before{content:'';position:absolute;inset:0;z-index:-1;background:radial-gradient(circle at 80% 50%,rgba(0,184,107,.4),transparent 60%),radial-gradient(circle at 15% 30%,rgba(61,91,255,.35),transparent 55%)}
.compband h3{font-family:var(--fs);font-weight:400;font-size:clamp(28px,3.5vw,44px);line-height:1.08;letter-spacing:-.015em;margin:0 0 12px;max-width:22ch}
.compband h3 em{font-style:italic;color:var(--pop-2)}
.compband .sub{color:rgba(255,255,255,.7);max-width:56ch;margin:0 0 36px;font-size:16px}
.compgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.compitem{padding:24px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:6px}
.compitem .k{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px}
.compitem .v{font-family:var(--fs);font-size:18px;font-weight:500;letter-spacing:-.01em}
@media(max-width:900px){.compgrid{grid-template-columns:1fr 1fr}.compband{padding:40px 28px}}

/* Cases */
.cases{display:flex;flex-direction:column}
.case{display:grid;grid-template-columns:100px 1.2fr 1.4fr 160px;gap:40px;padding:32px 0;border-top:1px solid var(--line);align-items:center;transition:padding .3s;text-decoration:none;color:inherit}
.case:last-child{border-bottom:1px solid var(--line)}
.case:hover{padding-left:16px;background:linear-gradient(to right,var(--paper),transparent 80%)}
.case-n{font-family:var(--fm);font-size:12px;color:var(--muted);letter-spacing:.08em}
.case-name{font-family:var(--fs);font-weight:500;font-size:26px;letter-spacing:-.015em;margin:0 0 4px;line-height:1.1}
.case-sec{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.case-r{font-size:14px;color:var(--ink-2);margin:0;max-width:42ch}
.case-r strong{background:linear-gradient(120deg,var(--pop-1),var(--pop-5));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}
.case-arr{display:flex;justify-content:flex-end}
.case-arr .a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;transition:all .25s;font-style:normal}
.case:hover .case-arr .a{background:linear-gradient(135deg,var(--pop-1),var(--pop-5));color:#fff;border-color:transparent;transform:rotate(-45deg)}
@media(max-width:900px){.case{grid-template-columns:1fr;gap:10px}.case-arr{justify-content:flex-start}}

/* Pricing */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pkg{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:36px 32px;display:flex;flex-direction:column;gap:20px;position:relative;transition:all .25s}
.pkg.feat-pkg{border:2px solid transparent;background:
  linear-gradient(var(--paper),var(--paper)) padding-box,
  linear-gradient(135deg,var(--pop-1),var(--pop-4) 50%,var(--pop-5)) border-box;
  transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(61,91,255,.35)}
.pkg-tag{position:absolute;top:-12px;left:32px;padding:4px 12px;font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(135deg,var(--pop-1),var(--pop-5));color:#fff;border-radius:3px}
.pkg .nm{font-family:var(--fm);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.pkg h3{font-family:var(--fs);font-weight:500;font-size:30px;letter-spacing:-.015em;margin:0}
.pkg .px{display:flex;align-items:baseline;gap:8px;padding-top:16px;border-top:1px solid var(--line)}
.pkg .px .v{font-family:var(--fs);font-size:42px;font-weight:500;letter-spacing:-.02em;line-height:1}
.pkg .px .u{font-family:var(--fm);font-size:12px;color:var(--muted);letter-spacing:.08em}
.pkg ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;flex:1}
.pkg ul li{font-size:14px;padding-left:22px;position:relative;color:var(--ink-2)}
.pkg ul li::before{content:'\2713';position:absolute;left:0;top:0;color:var(--pop-3);font-weight:700}
.pkg .btn{justify-content:center}
@media(max-width:900px){.pkg-grid{grid-template-columns:1fr}.pkg.feat-pkg{transform:none}}

/* FAQ */
.faq{display:grid;grid-template-columns:1fr;gap:10px;max-width:880px}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:6px;transition:border-color .2s}
.faq details[open]{border-color:var(--pop-1)}
.faq summary{padding:22px 28px;font-family:var(--fs);font-size:20px;font-weight:500;letter-spacing:-.01em;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--fn);font-weight:300;font-size:28px;color:var(--pop-1);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0;padding:0 28px 24px;color:var(--muted);font-size:15px;line-height:1.6}

/* Related services */
.rel{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rel a{padding:28px 24px;background:var(--paper);border:1px solid var(--line);border-radius:8px;display:flex;flex-direction:column;gap:8px;min-height:150px;transition:all .25s;text-decoration:none;color:inherit}
.rel a:hover{transform:translateY(-3px);box-shadow:0 16px 32px -16px rgba(0,0,0,.15)}
.rel a:nth-child(1):hover{border-color:var(--pop-1)}
.rel a:nth-child(2):hover{border-color:var(--pop-2)}
.rel a:nth-child(3):hover{border-color:var(--pop-4)}
.rel a:nth-child(4):hover{border-color:var(--pop-5)}
.rel .rn{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.rel h4{font-family:var(--fs);font-weight:500;font-size:20px;letter-spacing:-.01em;margin:0}
.rel p{font-size:13px;color:var(--muted);margin:auto 0 0}
.rel .arr{font-family:var(--fm);margin-top:8px;color:var(--pop-1)}
@media(max-width:900px){.rel{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.rel{grid-template-columns:1fr}}

/* CTA — service page overrides */
.cta-wrap{padding:120px 0}
.cta{background:var(--ink);color:#fff;border-radius:10px;padding:80px;position:relative;overflow:hidden;isolation:isolate}
.cta::before{content:'';position:absolute;top:-150px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,31,.35),transparent 60%);z-index:-1}
.cta::after{content:'';position:absolute;bottom:-180px;left:-120px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(61,91,255,.3),transparent 60%);z-index:-1}
.cta-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:end}
.cta h2{font-family:var(--fs);font-weight:400;font-size:clamp(40px,5.5vw,72px);line-height:1.03;letter-spacing:-.025em;margin:0;max-width:16ch}
.cta h2 em{font-style:italic;background:linear-gradient(120deg,var(--pop-2),var(--pop-1),var(--pop-5));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cta-info{display:grid;gap:20px}
.cta-info .r{display:flex;gap:16px;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12)}
.cta-info .r:last-child{border-bottom:none}
.cta-info .lb{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);min-width:100px}
.cta-info .v{font-family:var(--fs);font-size:18px}
.cta-foot{margin-top:48px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.cta .btn-p{background:linear-gradient(135deg,var(--pop-1),var(--pop-2));color:#fff}
.cta .btn-g{border-color:rgba(255,255,255,.25);color:#fff}
.cta .btn-g:hover{background:#fff;color:var(--ink)}
@media(max-width:900px){.cta{padding:44px}.cta-grid{grid-template-columns:1fr}}
