/* ============================================================
   SERVICE PAGE DESIGN — sp-design.css  v2.0
   Uses CSS custom properties from style.css for automatic
   light/dark mode support via data-theme="dark"
   ============================================================ */

/* ── Typography ─────────────────────────────────────────── */
body { font-family:'Plus Jakarta Sans',Arial,Helvetica,sans-serif; }
h1,h2,h3,h4 { font-family:'Plus Jakarta Sans',Arial,Helvetica,sans-serif; letter-spacing:-.03em; }

/* ── Hero ───────────────────────────────────────────────── */
.sp-hero {
    background:linear-gradient(135deg,#06254a 0%,#0b4a8a 60%,#063b73 100%);
    position:relative; overflow:hidden; padding:0;
}
[data-theme="dark"] .sp-hero {
    background:linear-gradient(135deg,#020a15 0%,#061830 60%,#041223 100%);
}
.sp-hero::before {
    content:''; position:absolute; top:-120px; right:-80px;
    width:520px; height:520px; border-radius:50%;
    background:radial-gradient(circle,rgba(255,138,0,.18) 0%,transparent 70%);
    pointer-events:none;
}
.sp-hero::after {
    content:''; position:absolute; bottom:-1px; left:0; right:0;
    height:48px; background:var(--bg,#F4F7FF);
    clip-path:ellipse(55% 100% at 50% 100%);
}
.sp-hero-inner {
    display:grid; grid-template-columns:1fr 1fr;
    gap:0; align-items:stretch; min-height:360px;
}
.sp-hero-text {
    padding:20px 52px 48px 0;
    display:flex; flex-direction:column; justify-content:flex-start;
}
.sp-hero-text .eyebrow { color:#f59e0b; margin-bottom:14px; }
.sp-hero-text h1 {
    color:#fff; font-size:clamp(30px,3.8vw,50px);
    line-height:1.08; margin:0 0 12px; letter-spacing:-.04em;
}
.sp-hero-text p { color:rgba(219,238,255,.85); font-size:16.5px; line-height:1.75; margin:0 0 14px; }
.sp-hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; }
.sp-btn-primary {
    display:inline-flex; align-items:center; gap:8px;
    background:var(--orange,#ff8a00); color:#fff; border-radius:999px;
    padding:14px 26px; font-weight:800; font-size:15px;
    border:0; cursor:pointer; text-decoration:none;
    box-shadow:0 12px 28px rgba(255,138,0,.35);
    transition:transform .2s,box-shadow .2s;
}
.sp-btn-primary:hover { transform:translateY(-2px); box-shadow:0 18px 36px rgba(255,138,0,.45); }
.sp-btn-secondary {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,255,255,.12); color:#fff;
    border:1.5px solid rgba(255,255,255,.35); border-radius:999px;
    padding:13px 24px; font-weight:800; font-size:15px;
    text-decoration:none; transition:background .2s;
}
.sp-btn-secondary:hover { background:rgba(255,255,255,.22); }
.sp-hero-badges {
    display:flex; flex-wrap:wrap; gap:7px; margin-top:22px;
}
.sp-hero-badges span {
    background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.22);
    color:rgba(255,255,255,.90); border-radius:6px;
    padding:5px 11px; font-size:12px; font-weight:700;
}
.sp-hero-img { position:relative; overflow:hidden; background:rgba(6,37,74,.5); }
.sp-hero-img img { width:100%; height:100%; object-fit:cover; object-position:center; opacity:.78; display:block; }
.sp-hero-img-overlay { position:absolute; bottom:32px; left:24px; right:24px; display:flex; gap:10px; flex-wrap:wrap; }
.sp-stat-float {
    background:rgba(255,255,255,.95); border-radius:14px;
    padding:12px 16px; box-shadow:0 8px 24px rgba(0,0,0,.25); flex:1; min-width:110px;
}
[data-theme="dark"] .sp-stat-float { background:rgba(13,31,53,.96); }
.sp-stat-float strong { display:block; color:#063b73; font-size:22px; font-weight:900; line-height:1; }
[data-theme="dark"] .sp-stat-float strong { color:#93c5fd; }
.sp-stat-float span { display:block; color:#64748b; font-size:11px; font-weight:700; margin-top:3px; }
[data-theme="dark"] .sp-stat-float span { color:#94a3b8; }

/* ── Breadcrumb ──────────────────────────────────────────── */
.sp-breadcrumb { padding:12px 0 0; }
.sp-breadcrumb ol { list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:4px; align-items:center; }
.sp-breadcrumb li { font-size:13px; color:rgba(219,238,255,.65); font-weight:700; }
.sp-breadcrumb li a { color:rgba(219,238,255,.8); text-decoration:none; }
.sp-breadcrumb li a:hover { color:#fff; }
.sp-breadcrumb li+li::before { content:'›'; margin-right:4px; opacity:.6; }

/* ── Trust strip ─────────────────────────────────────────── */
.sp-trust-strip { background:var(--surf,#fff); border-top:1px solid var(--bdr,#D5DCF0); border-bottom:1px solid var(--bdr,#D5DCF0); padding:16px 0; }
.sp-trust-inner { display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.sp-trust-label { font-size:11px; font-weight:800; color:#94a3b8; text-transform:uppercase; letter-spacing:.1em; flex-shrink:0; }
.sp-trust-badges { display:flex; gap:9px; flex-wrap:wrap; align-items:center; }
.sp-trust-badge {
    display:inline-flex; align-items:center; gap:6px;
    background:var(--surf2,#EEF2FF); border:1.5px solid var(--bdr,#D5DCF0);
    border-radius:8px; padding:7px 12px; font-size:12.5px; font-weight:800; color:var(--t1,#0B1736);
}
.sp-trust-badge .tb-icon { font-size:15px; }
.sp-trust-badge.green { border-color:#bbf7d0; background:#f0fdf4; color:#15803d; }
.sp-trust-badge.blue  { border-color:#bae6fd; background:#f0f9ff; color:#0369a1; }
.sp-trust-badge.orange { border-color:#fed7aa; background:#fff7ed; color:#c2410c; }
[data-theme="dark"] .sp-trust-badge { background:var(--surf2,#152338); border-color:var(--bdr); color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-trust-badge.green { background:rgba(22,101,52,.2); border-color:rgba(134,239,172,.2); color:#9ff2b7; }
[data-theme="dark"] .sp-trust-badge.blue  { background:rgba(3,105,161,.2); border-color:rgba(186,230,253,.2); color:#7dd3fc; }
[data-theme="dark"] .sp-trust-badge.orange { background:rgba(194,65,12,.2); border-color:rgba(254,215,170,.2); color:#fdba74; }

/* ── Stats strip ─────────────────────────────────────────── */
.sp-stats-strip { background:var(--surf,#fff); padding:28px 0; border-bottom:1px solid var(--bdr,#D5DCF0); }
.sp-stats-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.sp-stat-card {
    text-align:center; padding:20px 12px; border-radius:18px;
    border:1.5px solid var(--bdr,#D5DCF0); background:var(--surf2,#EEF2FF);
    transition:transform .2s,box-shadow .2s;
}
.sp-stat-card:hover { transform:translateY(-3px); box-shadow:0 12px 28px rgba(11,79,174,.08); }
.sp-stat-card strong { display:block; color:#063b73; font-size:36px; font-weight:900; line-height:1; letter-spacing:-.04em; }
.sp-stat-card span { display:block; color:var(--t2,#374369); font-weight:700; font-size:12px; margin-top:5px; }
[data-theme="dark"] .sp-stat-card { background:var(--surf2,#152338); border-color:var(--bdr); }
[data-theme="dark"] .sp-stat-card strong { color:#93c5fd; }
[data-theme="dark"] .sp-stat-card span { color:var(--t2,#7A98C5); }

/* ── Section base ─────────────────────────────────────────── */
.sp-section { padding:76px 0; background:var(--bg,#F4F7FF); }
.sp-section-light { background:var(--surf,#fff); }
[data-theme="dark"] .sp-section { background:var(--bg,#060D1A); }
[data-theme="dark"] .sp-section-light { background:var(--surf,#0F1C30); }
.sp-sec-head { text-align:left; max-width:100%; margin:0 0 44px; }
.sp-sec-head .eyebrow { margin-bottom:10px; }
.sp-sec-head h2 { color:var(--t1,#0B1736); font-size:clamp(25px,3.5vw,38px); margin:0 0 12px; }
.sp-sec-head p { color:var(--t2,#374369); font-size:15.5px; line-height:1.75; margin:0; }
[data-theme="dark"] .sp-sec-head h2 { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-sec-head p { color:var(--t2,#7A98C5); }

/* ── Service cards ───────────────────────────────────────── */
.sp-service-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.sp-service-card {
    background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0);
    border-radius:20px; padding:26px; position:relative; overflow:hidden;
    transition:border-color .22s,box-shadow .22s,transform .22s;
}
.sp-service-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:4px;
    background:linear-gradient(90deg,var(--orange,#ff8a00),#ff5722); opacity:0; transition:opacity .22s;
}
.sp-service-card:hover { border-color:#bae6fd; box-shadow:0 16px 40px rgba(11,79,174,.1); transform:translateY(-3px); }
.sp-service-card:hover::before { opacity:1; }
.sp-card-num { font-size:12.5px; font-weight:900; color:var(--orange,#ff8a00); letter-spacing:.06em; margin-bottom:10px; display:block; }
.sp-service-card h3 { color:var(--t1,#0B1736); font-size:17px; margin:0 0 10px; line-height:1.3; }
.sp-service-card p { color:var(--t2,#374369); font-size:14px; line-height:1.75; margin:0; }
[data-theme="dark"] .sp-service-card { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-service-card h3 { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-service-card p { color:var(--t2,#7A98C5); }

/* ── Overview ─────────────────────────────────────────────── */
.sp-overview-grid { display:grid; grid-template-columns:1fr 1.15fr; gap:44px; align-items:start; }
.sp-panel {
    background:var(--surf2,#EEF2FF); border:1.5px solid var(--bdr,#D5DCF0); border-radius:20px; padding:28px;
}
.sp-panel h2 { color:var(--t1,#0B1736); font-size:21px; margin:10px 0 18px; }
[data-theme="dark"] .sp-panel { background:var(--surf2,#152338); border-color:var(--bdr); }
[data-theme="dark"] .sp-panel h2 { color:var(--t1,#DCE8FF); }
.sp-checklist { list-style:none; padding:0; margin:0; display:grid; gap:9px; }
.sp-checklist li {
    display:flex; align-items:flex-start; gap:9px;
    background:var(--surf,#fff); border:1px solid var(--bdr,#D5DCF0);
    border-radius:12px; padding:11px 13px;
    font-weight:700; font-size:13.5px; color:var(--t1,#0B1736);
}
.sp-checklist li::before { content:'✓'; color:var(--orange,#ff8a00); font-weight:900; flex-shrink:0; }
[data-theme="dark"] .sp-checklist li { background:var(--surf,#0F1C30); border-color:var(--bdr); color:var(--t1,#DCE8FF); }
.sp-body-text p { color:var(--t2,#374369); line-height:1.8; margin:0 0 16px; font-size:15px; }
.sp-body-text p:last-child { margin-bottom:0; }
[data-theme="dark"] .sp-body-text p { color:var(--t2,#7A98C5); }

/* ── Process timeline ─────────────────────────────────────── */
.sp-process-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; position:relative; }
.sp-process-grid::before {
    content:''; position:absolute; top:34px; left:calc(16.66% + 16px); right:calc(16.66% + 16px);
    height:2px; background:linear-gradient(90deg,var(--orange,#ff8a00),#0b66c3); z-index:0;
}
.sp-step { text-align:center; padding:0 16px; position:relative; z-index:1; }
.sp-step-num {
    width:68px; height:68px; border-radius:50%;
    background:linear-gradient(135deg,#06254a,#0b66c3); color:#fff;
    font-size:22px; font-weight:900;
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 16px; box-shadow:0 8px 24px rgba(6,37,74,.25); position:relative;
}
.sp-step-num::after { content:''; position:absolute; inset:-4px; border-radius:50%; border:2px solid rgba(255,138,0,.35); }
.sp-step h3 { color:var(--t1,#0B1736); font-size:15.5px; margin:0 0 8px; }
.sp-step p  { color:var(--t2,#374369); font-size:13.5px; line-height:1.65; margin:0; }
[data-theme="dark"] .sp-step h3 { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-step p  { color:var(--t2,#7A98C5); }

/* ── Mid CTA band ─────────────────────────────────────────── */
.sp-cta-band { background:linear-gradient(135deg,#06254a 0%,#0b4a8a 100%); padding:52px 0; position:relative; overflow:hidden; }
[data-theme="dark"] .sp-cta-band { background:linear-gradient(135deg,#020a15 0%,#061830 100%); }
.sp-cta-band::before { content:''; position:absolute; right:-60px; top:-60px; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle,rgba(255,138,0,.15),transparent 65%); }
.sp-cta-inner { max-width:100%; margin:0; text-align:left; }
.sp-cta-inner h2 { color:#fff; font-size:clamp(22px,3vw,34px); margin:0 0 12px; }
.sp-cta-inner p { color:rgba(219,238,255,.85); font-size:15.5px; line-height:1.7; margin:0 0 26px; }
.sp-cta-note { margin-top:12px !important; font-size:13px !important; opacity:.68; }

/* ── Testimonials ─────────────────────────────────────────── */
.sp-testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.sp-testi-card {
    background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0); border-radius:20px;
    padding:26px; display:flex; flex-direction:column;
    box-shadow:0 6px 22px rgba(15,23,42,.05);
    transition:box-shadow .2s,transform .2s;
}
.sp-testi-card:hover { box-shadow:0 14px 38px rgba(15,23,42,.1); transform:translateY(-3px); }
.sp-stars { color:#f59e0b; font-size:17px; letter-spacing:2px; margin-bottom:14px; }
.sp-testi-quote { color:var(--t2,#374369); font-size:14px; line-height:1.75; flex:1; font-style:italic; }
.sp-testi-quote::before { content:'\201C'; color:var(--orange,#ff8a00); font-size:40px; line-height:1; display:block; margin-bottom:-8px; font-style:normal; }
.sp-testi-meta { margin-top:20px; padding-top:16px; border-top:1px solid var(--bdr,#D5DCF0); }
.sp-testi-meta strong { display:block; color:var(--t1,#0B1736); font-size:13.5px; font-weight:800; }
.sp-testi-meta span { color:#64748b; font-size:12.5px; margin-top:2px; display:block; }
[data-theme="dark"] .sp-testi-card { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-testi-quote { color:var(--t2,#7A98C5); }
[data-theme="dark"] .sp-testi-meta strong { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-testi-meta { border-color:var(--bdr); }

/* ── Industries ──────────────────────────────────────────── */
.sp-industry-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.sp-ind-card {
    background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0); border-radius:16px;
    padding:20px 16px; transition:border-color .2s,transform .2s;
}
.sp-ind-card:hover { border-color:var(--orange,#ff8a00); transform:translateY(-3px); }
.sp-ind-icon { width:42px; height:42px; margin-bottom:10px; }
.sp-ind-card h3 { color:var(--t1,#0B1736); font-size:14.5px; font-weight:800; margin:0 0 7px; }
.sp-ind-card p { color:var(--t2,#374369); font-size:13px; line-height:1.6; margin:0; }
[data-theme="dark"] .sp-ind-card { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-ind-card h3 { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-ind-card p { color:var(--t2,#7A98C5); }

/* ── FAQ ─────────────────────────────────────────────────── */
.sp-faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.sp-faq-item {
    background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0); border-radius:16px;
    padding:20px 22px; cursor:pointer; transition:border-color .2s,box-shadow .2s;
}
.sp-faq-item:hover { border-color:#bae6fd; box-shadow:0 8px 24px rgba(11,79,174,.07); }
.sp-faq-item h3 { color:var(--t1,#0B1736); font-size:14.5px; font-weight:800; margin:0 0 9px; display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.sp-faq-item h3::after { content:'+'; color:var(--orange,#ff8a00); font-size:20px; font-weight:400; flex-shrink:0; line-height:1; }
.sp-faq-item p { color:var(--t2,#374369); font-size:13.5px; line-height:1.7; margin:0; }
[data-theme="dark"] .sp-faq-item { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-faq-item h3 { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-faq-item p { color:var(--t2,#7A98C5); }

/* ── Quality & Security ──────────────────────────────────── */
.sp-quality-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:start; }
.sp-security-badges { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sp-sec-badge {
    background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0); border-radius:14px;
    padding:14px 12px; text-align:center;
}
.sp-sec-badge .sb-icon { font-size:24px; display:block; margin-bottom:5px; }
.sp-sec-badge strong { display:block; color:var(--t1,#0B1736); font-size:12.5px; font-weight:800; }
.sp-sec-badge span { display:block; color:#64748b; font-size:11px; margin-top:2px; }
[data-theme="dark"] .sp-sec-badge { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-sec-badge strong { color:var(--t1,#DCE8FF); }

/* ── Inputs/Outputs ──────────────────────────────────────── */
.sp-io-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.sp-io-box { background:var(--surf,#fff); border:1.5px solid var(--bdr,#D5DCF0); border-radius:18px; padding:24px; }
.sp-io-box h3 { color:var(--t1,#0B1736); font-size:16px; font-weight:800; margin:0 0 14px; padding-bottom:10px; border-bottom:2px solid var(--surf2,#EEF2FF); }
.sp-io-box ul { list-style:none; padding:0; margin:0; display:grid; gap:7px; }
.sp-io-box li { display:flex; align-items:center; gap:8px; color:var(--t2,#374369); font-size:13.5px; font-weight:600; }
.sp-io-box li::before { content:'→'; color:var(--orange,#ff8a00); font-weight:900; }
[data-theme="dark"] .sp-io-box { background:var(--surf,#0F1C30); border-color:var(--bdr); }
[data-theme="dark"] .sp-io-box h3 { color:var(--t1,#DCE8FF); border-color:var(--surf2,#152338); }
[data-theme="dark"] .sp-io-box li { color:var(--t2,#7A98C5); }

/* ── Related services ────────────────────────────────────── */
.sp-related-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.sp-related-card {
    background:var(--surf2,#EEF2FF); border:1.5px solid var(--bdr,#D5DCF0); border-radius:14px;
    padding:16px; text-decoration:none; display:block;
    transition:background .2s,border-color .2s,transform .2s;
}
.sp-related-card:hover { background:var(--surf,#fff); border-color:#93c5fd; transform:translateY(-2px); }
.sp-related-card strong { display:block; color:var(--t1,#0B1736); font-size:13.5px; font-weight:800; margin-bottom:5px; }
.sp-related-card span { color:var(--t2,#374369); font-size:12px; line-height:1.55; }
.sp-related-card .sp-arrow { color:var(--orange,#ff8a00); font-weight:900; margin-top:8px; display:block; font-size:12.5px; }
[data-theme="dark"] .sp-related-card { background:var(--surf2,#152338); border-color:var(--bdr); }
[data-theme="dark"] .sp-related-card:hover { background:var(--surf,#0F1C30); border-color:rgba(147,197,253,.3); }
[data-theme="dark"] .sp-related-card strong { color:var(--t1,#DCE8FF); }
[data-theme="dark"] .sp-related-card span { color:var(--t2,#7A98C5); }

/* ── Why SDES photo section ──────────────────────────────── */
[data-theme="dark"] .sp-why-body p { color:var(--t2,#7A98C5); }

/* ── WebP picture element ────────────────────────────────── */
.sp-hero-picture { width:100%; height:100%; display:block; }
.sp-hero-picture img { width:100%; height:100%; object-fit:cover; object-position:center; opacity:.78; display:block; }

/* ── Sticky mobile CTA ───────────────────────────────────── */
.sp-sticky-cta {
    display:none; position:fixed; bottom:0; left:0; right:0; z-index:200;
    background:#06254a; padding:12px 18px;
    box-shadow:0 -4px 24px rgba(0,0,0,.2); border-top:1px solid rgba(255,255,255,.08);
}
[data-theme="dark"] .sp-sticky-cta { background:#020a15; }
.sp-sticky-cta a {
    display:flex; align-items:center; justify-content:center;
    background:var(--orange,#ff8a00); color:#fff; border-radius:12px;
    padding:13px; font-weight:900; font-size:14.5px; text-decoration:none; gap:7px;
}

/* ── WhatsApp float ──────────────────────────────────────── */
.sp-wa-float {
    position:fixed; right:20px; bottom:76px; z-index:190;
    width:52px; height:52px; border-radius:50%;
    background:#25D366; box-shadow:0 6px 20px rgba(37,211,102,.4);
    display:flex; align-items:center; justify-content:center;
    font-size:24px; text-decoration:none; transition:transform .2s,box-shadow .2s;
}
.sp-wa-float:hover { transform:scale(1.1); box-shadow:0 10px 28px rgba(37,211,102,.5); }

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:1050px){
    .sp-hero-inner { grid-template-columns:1fr; }
    .sp-hero-img { display:none; }
    .sp-hero-text { padding:56px 0 76px; }
    .sp-service-grid { grid-template-columns:repeat(2,1fr); }
    .sp-process-grid { grid-template-columns:1fr; }
    .sp-process-grid::before { display:none; }
    .sp-testi-grid { grid-template-columns:1fr; }
    .sp-industry-grid { grid-template-columns:repeat(2,1fr); }
    .sp-faq-grid { grid-template-columns:1fr; }
    .sp-related-grid { grid-template-columns:repeat(2,1fr); }
    .sp-stats-grid { grid-template-columns:repeat(3,1fr); }
    .sp-quality-grid { grid-template-columns:1fr; }
    .sp-io-grid { grid-template-columns:1fr; }
    .sp-overview-grid { grid-template-columns:1fr; }
    .sp-sticky-cta { display:block; }
}
@media(max-width:640px){
    .sp-service-grid { grid-template-columns:1fr; }
    .sp-industry-grid { grid-template-columns:1fr 1fr; }
    .sp-related-grid { grid-template-columns:1fr; }
    .sp-stats-grid { grid-template-columns:repeat(2,1fr); }
    .sp-security-badges { grid-template-columns:1fr 1fr; }
    .sp-trust-inner { flex-direction:column; align-items:flex-start; }
}

/* ============================================================
   DARK MODE — [data-theme="dark"] overrides
   ============================================================ */
[data-theme="dark"] .sp-trust-strip { background:#0e1b2f; border-color:rgba(255,255,255,.08); }
[data-theme="dark"] .sp-trust-badge { background:#132641; border-color:rgba(255,255,255,.12); color:#d7e7ff; }
[data-theme="dark"] .sp-trust-badge.green { background:rgba(22,101,52,.18); border-color:rgba(134,239,172,.2); color:#9ff2b7; }
[data-theme="dark"] .sp-trust-badge.blue { background:rgba(3,105,161,.18); border-color:rgba(125,211,252,.2); color:#7dd3fc; }
[data-theme="dark"] .sp-trust-badge.orange { background:rgba(194,65,12,.18); border-color:rgba(253,186,116,.2); color:#fbbf24; }
[data-theme="dark"] .sp-trust-label { color:#64748b; }
[data-theme="dark"] .sp-stats-strip { background:#0a1628; border-color:rgba(255,255,255,.08); }
[data-theme="dark"] .sp-stat-card { background:linear-gradient(135deg,#132641,#0e1b2f); border-color:rgba(255,255,255,.1); }
[data-theme="dark"] .sp-stat-card strong { color:#7dd3fc; }
[data-theme="dark"] .sp-stat-card span { color:#94a3b8; }
[data-theme="dark"] .sp-section-light { background:#09111f; }
[data-theme="dark"] .sp-section { background:transparent; }
[data-theme="dark"] .sp-service-card { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-service-card:hover { border-color:#0b66c3; }
[data-theme="dark"] .sp-service-card h3 { color:#f0f7ff; }
[data-theme="dark"] .sp-service-card p { color:#9ab8d8; }
[data-theme="dark"] .sp-card-num { color:#fb923c; }
[data-theme="dark"] .sp-panel { background:#132641; border-color:rgba(255,255,255,.1); }
[data-theme="dark"] .sp-panel h2 { color:#f0f7ff; }
[data-theme="dark"] .sp-checklist li { background:#0e1b2f; border-color:rgba(255,255,255,.09); color:#f0f7ff; }
[data-theme="dark"] .sp-checklist li::before { color:#fb923c; }
[data-theme="dark"] .sp-body-text p { color:#9ab8d8; }
[data-theme="dark"] .sp-overview-grid h2 { color:#f0f7ff; }
[data-theme="dark"] .sp-step h3 { color:#f0f7ff; }
[data-theme="dark"] .sp-step p { color:#9ab8d8; }
[data-theme="dark"] .sp-step-num { background:linear-gradient(135deg,#0b4a8a,#0b8fe8); }
[data-theme="dark"] .sp-process-grid::before { opacity:.35; }
[data-theme="dark"] .sp-sec-head h2 { color:#f0f7ff; }
[data-theme="dark"] .sp-sec-head p { color:#9ab8d8; }
[data-theme="dark"] .sp-testi-card { background:#0e1b2f; border-color:rgba(255,255,255,.09); box-shadow:none; }
[data-theme="dark"] .sp-testi-quote { color:#9ab8d8; }
[data-theme="dark"] .sp-testi-quote::before { color:#fb923c; }
[data-theme="dark"] .sp-testi-meta strong { color:#f0f7ff; }
[data-theme="dark"] .sp-testi-meta span { color:#64748b; }
[data-theme="dark"] .sp-testi-meta { border-top-color:rgba(255,255,255,.08); }
[data-theme="dark"] .sp-ind-card { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-ind-card:hover { border-color:#fb923c; }
[data-theme="dark"] .sp-ind-card h3 { color:#f0f7ff; }
[data-theme="dark"] .sp-ind-card p { color:#9ab8d8; }
[data-theme="dark"] .sp-faq-item { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-faq-item:hover { border-color:#0b66c3; }
[data-theme="dark"] .sp-faq-item h3 { color:#f0f7ff; }
[data-theme="dark"] .sp-faq-item h3::after { color:#fb923c; }
[data-theme="dark"] .sp-faq-item p { color:#9ab8d8; }
[data-theme="dark"] .sp-related-card { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-related-card:hover { background:#132641; border-color:#7dd3fc; }
[data-theme="dark"] .sp-related-card strong { color:#f0f7ff; }
[data-theme="dark"] .sp-related-card span { color:#9ab8d8; }
[data-theme="dark"] .sp-related-card .sp-arrow { color:#fb923c; }
[data-theme="dark"] .sp-io-box { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-io-box h3 { color:#f0f7ff; border-bottom-color:rgba(255,255,255,.08); }
[data-theme="dark"] .sp-io-box li { color:#9ab8d8; }
[data-theme="dark"] .sp-io-box li::before { color:#fb923c; }
[data-theme="dark"] .sp-sec-badge { background:#0e1b2f; border-color:rgba(255,255,255,.09); }
[data-theme="dark"] .sp-sec-badge strong { color:#f0f7ff; }
[data-theme="dark"] .sp-sec-badge span { color:#64748b; }
[data-theme="dark"] .sp-hero-badges span { background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.15); }
[data-theme="dark"] .sp-stat-float { background:#0e1b2f; }
[data-theme="dark"] .sp-stat-float strong { color:#7dd3fc; }
[data-theme="dark"] .sp-stat-float span { color:#64748b; }
[data-theme="dark"] .sp-breadcrumb li { color:rgba(219,238,255,.5); }
[data-theme="dark"] .sp-breadcrumb li a { color:rgba(219,238,255,.72); }
[data-theme="dark"] .sp-sticky-cta { background:#071121; border-top-color:rgba(255,255,255,.08); }
[data-theme="dark"] .sp-wa-float { box-shadow:0 6px 20px rgba(37,211,102,.3); }
[data-theme="dark"] .sp-btn-secondary { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.22); }

/* webp note — server should serve .webp; PNG is fallback */
/* Convert existing PNGs: cwebp -q 82 input.png -o output.webp */

/* ============================================================
   CRITICAL OVERRIDES — style.css applies !important to ALL
   h1-h6 (color, font-size) and ALL p (color). We need !important
   here to restore correct colours and sizes in service sections.
   ============================================================ */

/* ── Hero: white text on dark blue ── */
.sp-hero-text h1 {
  color: #fff !important;
  font-size: clamp(30px,3.8vw,50px) !important;
  line-height: 1.08 !important;
  letter-spacing: -.04em !important;
}
.sp-hero-text p {
  color: rgba(219,238,255,.85) !important;
  font-size: 16.5px !important;
  line-height: 1.75 !important;
}
.sp-breadcrumb li        { color: rgba(219,238,255,.65) !important; font-size: 13px !important; }
.sp-breadcrumb li a      { color: rgba(219,238,255,.8)  !important; }
.sp-hero-badges span     { color: rgba(255,255,255,.90) !important; }

/* ── Mid-CTA band: white text on dark blue ── */
.sp-cta-inner h2 {
  color: #fff !important;
  font-size: clamp(22px,3vw,34px) !important;
  line-height: 1.2 !important;
}
.sp-cta-inner p {
  color: rgba(219,238,255,.85) !important;
  font-size: 15.5px !important;
  line-height: 1.7 !important;
}

/* ── Section headings: restore sp-design sizes ── */
.sp-sec-head h2 {
  color: var(--t1,#0B1736) !important;
  font-size: clamp(25px,3.5vw,38px) !important;
  line-height: 1.15 !important;
  letter-spacing: -.03em !important;
}
.sp-sec-head p {
  color: var(--t2,#374369) !important;
  font-size: 15.5px !important;
  line-height: 1.75 !important;
}

/* ── Service cards ── */
.sp-service-card h3 {
  color: var(--t1,#0B1736) !important;
  font-size: 17px !important;
  line-height: 1.3 !important;
}
.sp-service-card p {
  color: var(--t2,#374369) !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

/* ── Overview panel ── */
.sp-panel h2 {
  color: var(--t1,#0B1736) !important;
  font-size: 21px !important;
}
.sp-body-text p {
  color: var(--t2,#374369) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

/* ── Process steps ── */
.sp-step h3 {
  color: var(--t1,#0B1736) !important;
  font-size: 15.5px !important;
}
.sp-step p  {
  color: var(--t2,#374369) !important;
  font-size: 13.5px !important;
  line-height: 1.65 !important;
}

/* ── Industry cards ── */
.sp-ind-card h3 {
  color: var(--t1,#0B1736) !important;
  font-size: 14.5px !important;
}
.sp-ind-card p {
  color: var(--t2,#374369) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

/* ── FAQ items ── */
.sp-faq-item h3 {
  color: var(--t1,#0B1736) !important;
  font-size: 14.5px !important;
}
.sp-faq-item p {
  color: var(--t2,#374369) !important;
  font-size: 13.5px !important;
  line-height: 1.7 !important;
}

/* ── I/O boxes ── */
.sp-io-box h3 {
  color: var(--t1,#0B1736) !important;
  font-size: 16px !important;
}
.sp-io-box li {
  color: var(--t2,#374369) !important;
  font-size: 13.5px !important;
}

/* ── Testimonials ── */
.sp-testi-quote {
  color: var(--t2,#374369) !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

/* ── Dark mode re-overrides ── */
[data-theme="dark"] .sp-hero-text h1    { color: #fff !important; }
[data-theme="dark"] .sp-hero-text p     { color: rgba(219,238,255,.85) !important; }
[data-theme="dark"] .sp-cta-inner h2   { color: #fff !important; }
[data-theme="dark"] .sp-cta-inner p    { color: rgba(219,238,255,.85) !important; }
[data-theme="dark"] .sp-sec-head h2    { color: var(--t1,#DCE8FF) !important; }
[data-theme="dark"] .sp-sec-head p     { color: var(--t2,#7A98C5) !important; }
[data-theme="dark"] .sp-service-card h3{ color: var(--t1,#DCE8FF) !important; }
[data-theme="dark"] .sp-service-card p { color: var(--t2,#7A98C5) !important; }
[data-theme="dark"] .sp-step h3        { color: #f0f7ff !important; }
[data-theme="dark"] .sp-step p         { color: #9ab8d8 !important; }
[data-theme="dark"] .sp-ind-card h3    { color: #f0f7ff !important; }
[data-theme="dark"] .sp-ind-card p     { color: #9ab8d8 !important; }
[data-theme="dark"] .sp-faq-item h3    { color: #f0f7ff !important; }
[data-theme="dark"] .sp-faq-item p     { color: #9ab8d8 !important; }
[data-theme="dark"] .sp-body-text p    { color: var(--t2,#7A98C5) !important; }
[data-theme="dark"] .sp-testi-quote    { color: var(--t2,#7A98C5) !important; }

/* ============================================================
   IMAGE FIT FIX — 2026-06-12
   Removes the dark/blue frame around hero images and prevents
   hero/Why SDES images from being cropped.
   ============================================================ */
.sp-hero-img {
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:transparent !important;
    border:0 !important;
    padding:0 !important;
    box-shadow:none !important;
    border-radius:18px !important;
    overflow:hidden !important;
}
.sp-hero-img picture,
.sp-hero-picture {
    display:block !important;
    width:100% !important;
    height:100% !important;
}
.sp-hero-img img,
.sp-hero-picture img {
    display:block !important;
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
    object-position:center center !important;
    opacity:1 !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
}
.sp-overview-grid picture {
    display:block !important;
    width:100% !important;
    background:#fff !important;
    border-radius:20px !important;
    overflow:hidden !important;
    box-shadow:0 16px 40px rgba(15,23,42,.12) !important;
}
.sp-overview-grid picture img {
    display:block !important;
    width:100% !important;
    height:auto !important;
    max-height:none !important;
    object-fit:contain !important;
    object-position:center center !important;
    border-radius:20px !important;
    background:#fff !important;
    box-shadow:none !important;
}
@media (max-width: 980px) {
    .sp-hero-img {
        min-height:auto !important;
        aspect-ratio:auto !important;
    }
    .sp-hero-img img,
    .sp-hero-picture img {
        height:auto !important;
    }
}

/* ============================================================
   HERO IMAGE BOX FIX — v2.8
   Keeps the Best Buy service-page layout, but gives the hero
   image a proper contained box so landscape/portrait images do
   not crop or stretch.
   ============================================================ */
.sp-hero-inner {
    grid-template-columns: minmax(0, .96fr) minmax(360px, 1.04fr) !important;
    gap: 44px !important;
    align-items: start !important;
    min-height: auto !important;
}
.sp-hero-text {
    padding: 20px 0 48px 0 !important;
}
.sp-hero-img {
    position: relative !important;
    align-self: start !important;
    display: block !important;
    width: 100% !important;
    max-width: 520px !important;
    margin: 18px 0 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
}
.sp-hero-img picture,
.sp-hero-picture {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 3 / 2 !important;
    background: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    line-height: 0 !important;
}
.sp-hero-img img,
.sp-hero-picture img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    opacity: 1 !important;
    background: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.sp-hero-img-overlay {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
    margin: 16px 0 0 0 !important;
    padding: 0 !important;
}
.sp-stat-float {
    min-width: 0 !important;
    flex: none !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
}
@media (max-width: 1050px) {
    .sp-hero-inner {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }
    .sp-hero-img {
        display: block !important;
        max-width: 560px !important;
        margin: 0 auto 46px auto !important;
    }
    .sp-hero-text {
        padding: 46px 0 0 0 !important;
    }
}
@media (max-width: 640px) {
    .sp-hero-img-overlay {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   HERO IMAGE BOX 600x900 FINAL — 2026-06-18
   Exact requested hero image container size.
   ============================================================ */
.sp-hero-inner {
    grid-template-columns: minmax(0, .96fr) minmax(600px, 600px) !important;
    gap: 44px !important;
    align-items: start !important;
}
.sp-hero-img {
    width: 600px !important;
    max-width: 600px !important;
    min-width: 600px !important;
    height: auto !important;
    margin: 18px 0 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
}
.sp-hero-img picture,
.sp-hero-picture {
    width: 600px !important;
    height: 900px !important;
    max-width: 600px !important;
    min-height: 900px !important;
    max-height: 900px !important;
    aspect-ratio: 600 / 900 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    line-height: 0 !important;
}
.sp-hero-img img,
.sp-hero-picture img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    opacity: 1 !important;
    background: #ffffff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.sp-hero-img-overlay {
    width: 600px !important;
    max-width: 600px !important;
    margin-top: 16px !important;
}
@media (max-width: 1180px) {
    .sp-hero-inner {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }
    .sp-hero-img {
        width: min(600px, 100%) !important;
        min-width: 0 !important;
        max-width: 600px !important;
        margin: 0 auto 46px auto !important;
    }
    .sp-hero-img picture,
    .sp-hero-picture {
        width: min(600px, 100%) !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        aspect-ratio: 600 / 900 !important;
    }
    .sp-hero-img img,
    .sp-hero-picture img {
        width: 100% !important;
        height: 100% !important;
        object-fit: contain !important;
    }
    .sp-hero-img-overlay {
        width: min(600px, 100%) !important;
        max-width: 600px !important;
    }
}


/* ============================================================
   AMAZON HERO PORTRAIT FINAL FIX — 2026-06-20
   Makes only the Amazon Product Data Entry hero match the Zoho
   CRM portrait layout. Requires:
   /images/hero/amazon-product-data-entry-hero.webp
   ============================================================ */
.sp-hero.sp-page-amazon-product-data-entry .container {
    max-width: 1120px !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 430px) 600px !important;
    gap: 48px !important;
    align-items: start !important;
    justify-content: center !important;
    min-height: auto !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-text {
    padding: 20px 0 48px 0 !important;
    max-width: 430px !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img.sp-hero-img-portrait {
    width: 600px !important;
    min-width: 600px !important;
    max-width: 600px !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: block !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img picture,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture {
    display: block !important;
    width: 600px !important;
    height: 900px !important;
    min-width: 600px !important;
    max-width: 600px !important;
    min-height: 900px !important;
    max-height: 900px !important;
    aspect-ratio: 2 / 3 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    line-height: 0 !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img img,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture img {
    display: block !important;
    width: 600px !important;
    height: 900px !important;
    max-width: 600px !important;
    max-height: 900px !important;
    object-fit: cover !important;
    object-position: center center !important;
    opacity: 1 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img-overlay {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 600px !important;
    max-width: 600px !important;
    margin: 14px 0 0 0 !important;
    padding: 0 !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-stat-float {
    min-width: 0 !important;
    flex: none !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
}
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img picture,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-img img,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture,
.sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture img,
.sp-hero.sp-page-amazon-product-data-entry .sp-overview-grid picture,
.sp-hero.sp-page-amazon-product-data-entry .sp-overview-grid picture img {
    background-color: transparent !important;
}
@media (max-width: 1180px) {
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-inner {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
        justify-items: center !important;
    }
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-text {
        max-width: 600px !important;
        width: 100% !important;
        padding-bottom: 0 !important;
    }
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-img,
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-img.sp-hero-img-portrait {
        width: min(600px, 100%) !important;
        min-width: 0 !important;
        max-width: 600px !important;
        margin: 0 auto 46px auto !important;
    }
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-img picture,
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture,
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-img img,
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-picture img {
        width: min(600px, 100%) !important;
        height: auto !important;
        min-width: 0 !important;
        min-height: 0 !important;
        max-width: 600px !important;
        max-height: none !important;
        aspect-ratio: 2 / 3 !important;
    }
    .sp-hero.sp-page-amazon-product-data-entry .sp-hero-img-overlay {
        width: min(600px, 100%) !important;
        max-width: 600px !important;
    }
}
