.service-hero{
    padding:30px 0 14px;
    background:
        radial-gradient(circle at 12% 18%, rgba(37,99,235,.12), transparent 28%),
        radial-gradient(circle at 86% 16%, rgba(249,115,22,.10), transparent 24%),
        linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);
}

.service-hero__shell{
    position:relative;
    overflow:hidden;
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:24px;
    align-items:stretch;
    padding:24px;
    border:1px solid rgba(255,255,255,.14);
    border-radius:32px;
    background:
        radial-gradient(circle at 84% 14%, rgba(96,165,250,.22), transparent 30%),
        radial-gradient(circle at 12% 90%, rgba(249,115,22,.16), transparent 26%),
        linear-gradient(135deg,#020617 0%,#0f172a 56%,#102a4b 100%);
    box-shadow:
        0 28px 78px rgba(15,23,42,.20),
        inset 0 1px 0 rgba(255,255,255,.08);
}

.service-hero__shell:before{
    content:"";
    position:absolute;
    inset:14px;
    pointer-events:none;
    border:1px solid rgba(255,255,255,.08);
    border-radius:26px;
}

.service-hero__content,
.service-hero__panel{
    position:relative;
    z-index:1;
}

.service-hero__content{
    min-width:0;
    padding:8px 4px 8px 6px;
}

.service-hero h1{
    margin:0;
    max-width:880px;
    color:#ffffff;
    font-size:clamp(38px,5vw,64px);
    line-height:1;
    letter-spacing:-.065em;
}

.service-hero p{
    margin:18px 0 0;
    max-width:820px;
    color:#dbeafe;
    font-size:18px;
    line-height:1.66;
}

.service-hero .hero-actions{
    margin-top:28px;
}

.service-hero__panel{
    padding:18px;
    border:1px solid rgba(255,255,255,.70);
    border-radius:24px;
    background:
        linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.96));
    color:#0f172a;
    box-shadow:0 20px 54px rgba(0,0,0,.18);
}

.service-hero__panel strong{
    display:block;
    color:#0f172a;
    font-size:21px;
    line-height:1.16;
    font-weight:950;
    letter-spacing:-.04em;
}

.service-hero__panel span{
    display:block;
    margin-top:10px;
    padding:11px 13px;
    border:1px solid rgba(37,99,235,.22);
    border-radius:14px;
    background:#eff6ff;
    color:#1d4ed8;
    font-size:13px;
    font-weight:750;
    line-height:1.55;
}

.service-hero__panel ul{
    display:grid;
    gap:8px;
    margin:12px 0 0;
    padding:0;
    list-style:none;
}

.service-hero__panel li{
    position:relative;
    margin:0;
    padding:9px 11px 9px 26px;
    border:1px solid #e2e8f0;
    border-radius:15px;
    background:#ffffff;
    color:#334155;
    font-size:13px;
    font-weight:750;
    line-height:1.38;
}

.service-hero__panel li:before{
    content:"";
    position:absolute;
    left:11px;
    top:15px;
    width:7px;
    height:7px;
    border-radius:50%;
    background:#1d4ed8;
    box-shadow:0 0 0 4px rgba(37,99,235,.10);
}

.service-detail{
    padding:28px 0 38px;
    background:
        radial-gradient(circle at 8% 14%, rgba(37,99,235,.07), transparent 24%),
        linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}

.service-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) 340px;
    gap:20px;
    align-items:start;
}

.service-article{
    min-width:0;
    padding:28px;
    border:1px solid #e2e8f0;
    border-radius:26px;
    background:#ffffff;
    box-shadow:
        0 20px 52px rgba(15,23,42,.08),
        inset 0 1px 0 rgba(255,255,255,.75);
}

.service-cover{
    margin:0 0 24px;
    overflow:hidden;
    border:1px solid #e2e8f0;
    border-radius:24px;
    background:#ffffff;
    aspect-ratio:16 / 9;
    box-shadow:0 18px 50px rgba(15,23,42,.08);
}

.service-cover img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}

.content-body{
    color:#334155;
    font-size:17px;
    line-height:1.78;
}

.content-body > *:first-child{
    margin-top:0;
}

.content-body h2,
.content-body h3{
    color:#0f172a;
    line-height:1.14;
    font-weight:900;
    letter-spacing:-.04em;
}

.content-body h2{
    margin:30px 0 12px;
    font-size:30px;
}

.content-body h3{
    margin:24px 0 10px;
    font-size:24px;
}

.content-body p{
    margin:0 0 16px;
    color:#374151;
    line-height:1.78;
}

.content-body ul,
.content-body ol{
    margin:14px 0 18px;
    padding-left:22px;
}

.content-body li{
    margin:8px 0;
    color:#374151;
    line-height:1.66;
}

.content-body strong,
.content-body b,
.service-article strong,
.service-block strong,
.service-faq strong,
.service-sidebar strong{
    color:#111827;
    font-weight:850;
}

.service-article .content-body a,
.service-block .content-body a{
    color:#b91c1c;
    font-weight:850;
    text-decoration:underline;
    text-decoration-thickness:1px;
    text-underline-offset:3px;
}

.service-article .content-body a:hover,
.service-block .content-body a:hover{
    color:#1d4ed8;
}

.service-block{
    margin-top:24px;
    padding-top:24px;
    border-top:1px solid #e2e8f0;
}

.service-block h2{
    margin:0 0 14px;
    color:#0f172a;
    font-size:32px;
    line-height:1.12;
    font-weight:900;
    letter-spacing:-.05em;
}

.service-sidebar{
    position:sticky;
    top:96px;
    display:grid;
    gap:14px;
}

.service-side-card{
    padding:22px;
    border:1px solid #e2e8f0;
    border-radius:24px;
    background:#ffffff;
    box-shadow:0 18px 44px rgba(15,23,42,.075);
}

.service-side-card strong{
    display:block;
    color:#0f172a;
    font-size:21px;
    line-height:1.16;
    font-weight:950;
    letter-spacing:-.04em;
}

.service-side-card p{
    margin:11px 0 0;
    color:#475569;
    font-size:14px;
    line-height:1.65;
}

.service-side-card .btn{
    margin-top:16px;
}

.service-side-card.muted{
    background:
        linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}

.btn.full{
    width:100%;
}

.service-faq{
    padding:26px 0 38px;
    background:#f8fafc;
}

.related-services{
    padding:26px 0 42px;
    background:#ffffff;
}
