/* Shared service-page styles. Brand tokens come from components.js (:root). */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--gray-900);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;padding-bottom:68px}
@media(min-width:900px){body{padding-bottom:0}}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:760px;margin:0 auto;padding:0 20px}
.crumb{font-size:13px;color:var(--gray-500);padding:14px 0 0;max-width:760px;margin:0 auto}
.crumb a{color:var(--blue);font-weight:700}

/* hero */
.svc-hero{position:relative;color:#fff;overflow:hidden;background:var(--navy)}
.svc-hero img{width:100%;height:54vh;min-height:320px;max-height:520px;object-fit:cover;display:block}
.svc-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(15,32,53,.45) 0%,rgba(15,32,53,.15) 35%,rgba(15,32,53,.75) 80%,var(--navy) 100%)}
.svc-hero-in{position:absolute;inset:auto 0 0 0;z-index:2;padding:0 20px 30px;text-align:center}
.svc-hero .label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light);margin-bottom:8px}
.svc-hero h1{font-family:var(--font-display);font-size:32px;font-weight:800;line-height:1.12;letter-spacing:-.02em;margin-bottom:10px;text-shadow:0 2px 18px rgba(0,0,0,.4);max-width:640px;margin-left:auto;margin-right:auto}
.svc-hero h1 span{color:var(--gold-light)}
.svc-hero p{font-size:15px;color:rgba(255,255,255,.82);max-width:480px;margin:0 auto 16px}
.svc-hero .cta{display:inline-flex;align-items:center;gap:9px;padding:15px 26px;border-radius:12px;background:var(--gold);color:var(--navy);font-weight:900;font-size:16px;box-shadow:0 6px 20px rgba(200,150,46,.4)}
@media(min-width:600px){.svc-hero h1{font-size:42px}.svc-hero img{height:60vh}}

.trust-strip{background:var(--blue-faint);border-bottom:1px solid var(--blue-pale);padding:14px 20px;display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--navy-mid);white-space:nowrap}

.section{padding:46px 0}
.section.alt{background:var(--gray-50)}
.section.navy{background:var(--navy);color:#fff}
.section .label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#2B7CB8;margin-bottom:8px}
.section.navy .label{color:var(--blue-light)}
.h2{font-family:var(--font-display);font-size:26px;font-weight:800;line-height:1.2;margin-bottom:10px;letter-spacing:-.01em}
.section.navy .h2{color:#fff}
.desc{font-size:15px;color:var(--gray-500);line-height:1.65;margin-bottom:22px}
.section.navy .desc{color:rgba(255,255,255,.7)}
.lead{font-size:16px;color:var(--gray-700);line-height:1.7;margin-bottom:14px}

.feature-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:600px){.feature-grid{grid-template-columns:1fr 1fr}}
.feature{background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-sm)}
.feature h3{font-size:15px;font-weight:800;margin-bottom:4px}
.feature p{font-size:13px;color:var(--gray-500);line-height:1.55}
.feature .ic{width:40px;height:40px;border-radius:11px;background:var(--blue-pale);color:#2B6A99;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}

.steps{display:flex;flex-direction:column;gap:14px}
.step{display:flex;gap:14px;align-items:flex-start}
.step .n{width:38px;height:38px;border-radius:50%;background:rgba(91,164,217,.14);color:var(--blue-light);display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}
.step h3{font-size:15px;font-weight:700;margin-bottom:2px;color:#fff}
.step p{font-size:13px;color:rgba(255,255,255,.65);line-height:1.5}

.ba{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.ba figure{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gray-200);box-shadow:var(--sh-sm);background:#fff;position:relative}
.ba img{width:100%;height:auto;display:block}
.ba .tag{position:absolute;top:10px;left:10px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:6px}
.tag.before{background:rgba(15,32,53,.8);color:#fff}
.tag.after{background:rgba(27,122,61,.9);color:#fff}
.tag.step{background:rgba(200,150,46,.95);color:var(--navy)}


.faq{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.faq details{background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:4px 18px;transition:border-color .2s,box-shadow .2s}
.faq details[open]{border-color:var(--gold);box-shadow:var(--sh-md)}
.faq summary{font-size:15px;font-weight:700;color:var(--navy);padding:14px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:22px;color:var(--gold)}
.faq details[open] summary::after{content:'\2212'}
.faq p{font-size:14px;color:var(--gray-700);line-height:1.7;padding:0 0 14px}
.faq a{color:var(--blue);font-weight:700;text-decoration:underline}

.svc-cta{background:var(--navy);color:#fff;text-align:center;padding:44px 20px}
.svc-cta h2{font-family:var(--font-display);font-size:24px;font-weight:800;margin-bottom:8px}
.svc-cta p{font-size:14px;color:rgba(255,255,255,.7);max-width:440px;margin:0 auto 18px}
.svc-cta .row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.svc-cta a{display:inline-flex;align-items:center;gap:9px;padding:15px 24px;border-radius:12px;font-weight:900;font-size:16px}
.svc-cta .gold{background:var(--gold);color:var(--navy);box-shadow:0 6px 20px rgba(200,150,46,.35)}
.svc-cta .ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.22)}

.quote{background:var(--gold-faint);border:1px solid rgba(200,150,46,.2);border-radius:var(--r-lg);padding:18px 20px;margin-top:8px}
.quote .stars{color:#C8962E;letter-spacing:2px;margin-bottom:6px}
.quote p{font-size:14px;color:var(--gray-700);font-style:italic;line-height:1.6;margin-bottom:6px}
.quote .who{font-size:12px;color:var(--gray-500);font-weight:700}

/* no-crop showcase grid */
.shots{columns:1;column-gap:12px;margin-top:8px}
@media(min-width:560px){.shots{columns:2}}
.shots figure{break-inside:avoid;-webkit-column-break-inside:avoid;margin-bottom:12px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gray-200);box-shadow:var(--sh-sm);position:relative;background:var(--gray-50)}
.shots img{width:100%;height:auto;display:block}
.shots figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 12px 10px;background:linear-gradient(0deg,rgba(15,32,53,.82),transparent);color:#fff;font-size:12px;font-weight:700;line-height:1.3}

/* before/after drag slider (contained, centered) */
.ba-wrap{max-width:380px;margin:0 auto}
.ba-slider{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gray-200);box-shadow:var(--sh-md);background:#0B1626;user-select:none;touch-action:pan-y}
.ba-base{display:block;width:100%;height:auto}
.ba-clip{position:absolute;top:0;left:0;height:100%;width:50%;overflow:hidden;will-change:width}
.ba-clip img{position:absolute;top:0;left:0;height:100%;width:auto;max-width:none;display:block}
.ba-line{position:absolute;top:0;bottom:0;left:50%;width:3px;margin-left:-1.5px;background:#fff;box-shadow:0 0 8px rgba(0,0,0,.45);pointer-events:none;z-index:3}
.ba-line::before{content:'';position:absolute;top:50%;left:50%;width:40px;height:40px;transform:translate(-50%,-50%);border-radius:50%;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.4)}
.ba-line::after{content:'↔';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#0F2035;font-weight:900;font-size:18px}
.ba-chip{position:absolute;top:12px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:6px;pointer-events:none;z-index:2}
.ba-chip-l{left:12px;background:rgba(15,32,53,.82);color:#fff}
.ba-chip-r{right:12px;background:rgba(27,122,61,.92);color:#fff}
.ba-cap{position:absolute;left:0;right:0;bottom:0;padding:16px 12px 11px;background:linear-gradient(0deg,rgba(15,32,53,.85),transparent);color:#fff;font-size:12px;font-weight:700;pointer-events:none;z-index:2}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;background:transparent;-webkit-appearance:none;appearance:none;cursor:ew-resize;opacity:0;z-index:4}
.ba-range::-webkit-slider-thumb{-webkit-appearance:none;width:46px;height:600px}
.ba-range::-moz-range-thumb{width:46px;height:600px;border:0;background:transparent}
