/* ═══════════════════════════════════════════════════════════
   NOBLE DIGITAL — SERVICE PAGE SHARED STYLES
   All service page templates reference this file.
   Upload to your theme folder alongside the template files.
   ═══════════════════════════════════════════════════════════ */

/* ─── Foundation ─── */
.sv-container { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.sv-section-label { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; color: #2563eb; margin-bottom: 14px; }
.sv-pill { display: inline-block; font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: #2563eb; background: rgba(37,99,235,0.07); padding: 7px 20px; border-radius: 100px; margin-bottom: 24px; }

/* ─── Hero ─── */
.sv-hero { position: relative; padding: 160px 24px 80px; text-align: center; overflow: hidden; }
.sv-hero-bg { position: absolute; inset: 0; z-index: 0; }
.sv-hero-gradient { position: absolute; inset: 0; background: linear-gradient(180deg, #eef4ff 0%, #f4f7ff 40%, #fff 100%); }
.sv-hero-grid-pattern { position: absolute; inset: 0; opacity: 0.3; background-image: radial-gradient(#cbd5e1 1px, transparent 1px); background-size: 32px 32px; mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, black 20%, transparent 70%); -webkit-mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, black 20%, transparent 70%); }
.sv-hero-inner { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; }
.sv-hero h1 { font-family: Georgia, 'Times New Roman', serif; font-size: 3.2rem; font-weight: 700; color: #0f172a; line-height: 1.12; margin: 0 0 20px; letter-spacing: -0.035em; }
.sv-hero-sub { font-size: 1.12rem; line-height: 1.7; color: #64748b; max-width: 540px; margin: 0 auto 32px; }
.sv-hero-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 48px; }
.sv-hero-proof { display: flex; align-items: center; justify-content: center; gap: 24px; }
.sv-proof-item { text-align: center; }
.sv-proof-item strong { display: block; font-size: 1.1rem; font-weight: 700; color: #0f172a; }
.sv-proof-item span { font-size: 0.82rem; color: #94a3b8; }
.sv-proof-divider { width: 1px; height: 32px; background: #e2e8f0; }

/* ─── Buttons ─── */
.sv-btn-primary { display: inline-flex; align-items: center; gap: 6px; background: #2563eb; color: #fff !important; padding: 15px 28px; border-radius: 10px; text-decoration: none !important; font-weight: 600; font-size: 0.95rem; transition: all 0.2s; box-shadow: 0 2px 8px rgba(37,99,235,0.2); }
.sv-btn-primary:hover { background: #1d4ed8; transform: translateY(-1px); box-shadow: 0 4px 14px rgba(37,99,235,0.3); }
.sv-btn-primary span { transition: transform 0.2s; }
.sv-btn-primary:hover span { transform: translateX(3px); }
.sv-btn-ghost { display: inline-block; color: #64748b !important; padding: 15px 28px; border-radius: 10px; border: 1px solid #e2e8f0; text-decoration: none !important; font-weight: 500; font-size: 0.95rem; background: #fff; transition: all 0.2s; }
.sv-btn-ghost:hover { border-color: #cbd5e1; color: #334155 !important; background: #f8fafc; }

/* ─── Section Headings ─── */
.sv-section { padding: 88px 24px; text-align: center; }
.sv-section h2 { font-family: Georgia, serif; font-size: 2.2rem; font-weight: 700; color: #0f172a; line-height: 1.2; margin: 0 0 16px; letter-spacing: -0.02em; }
.sv-section h2 em { font-style: italic; color: #2563eb; }
.sv-section-sub { font-size: 1.05rem; color: #64748b; line-height: 1.6; max-width: 560px; margin: 0 auto 48px; }
.sv-section-sub-left { text-align: left; margin: 0 0 48px; }

/* ─── Problem Cards ─── */
.sv-problem { background: #fff; }
.sv-problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; text-align: left; }
.sv-problem-card { padding: 28px; background: #fef2f2; border-radius: 14px; border: 1px solid #fecaca; }
.sv-problem-icon { width: 44px; height: 44px; background: #fff; border-radius: 10px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; border: 1px solid #fecaca; }
.sv-problem-card h3 { font-size: 1.05rem; font-weight: 600; color: #0f172a; margin: 0 0 8px; }
.sv-problem-card p { font-size: 0.92rem; line-height: 1.6; color: #64748b; margin: 0; }

/* ─── Feature Cards ─── */
.sv-features { background: #f8fafc; }
.sv-features-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; text-align: left; }
.sv-feature-card { padding: 32px; background: #fff; border-radius: 14px; border: 1px solid #e2e8f0; transition: all 0.2s; }
.sv-feature-card:hover { border-color: #c7d2fe; box-shadow: 0 4px 20px rgba(37,99,235,0.06); transform: translateY(-2px); }
.sv-feature-highlight { grid-column: span 2; background: linear-gradient(135deg, #eff6ff, #f8fafc); border-color: #bfdbfe; }
.sv-feature-icon { width: 52px; height: 52px; background: #eff6ff; border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.sv-feature-card h3 { font-size: 1.1rem; font-weight: 600; color: #0f172a; margin: 0 0 8px; }
.sv-feature-card p { font-size: 0.92rem; line-height: 1.65; color: #64748b; margin: 0 0 16px; }
.sv-feature-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.sv-feature-tags span { font-size: 0.75rem; color: #2563eb; background: #eff6ff; padding: 4px 12px; border-radius: 100px; font-weight: 500; }

/* ─── Stats / Results ─── */
.sv-results { background: #0f172a; }
.sv-results h2 { color: #fff; }
.sv-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.sv-stat { padding: 32px 20px; background: #1e293b; border-radius: 14px; border: 1px solid #334155; }
.sv-stat-num { font-family: Georgia, serif; font-size: 1.7rem; font-weight: 700; color: #60a5fa; margin-bottom: 8px; }
.sv-stat-label { font-size: 0.85rem; color: #94a3b8; line-height: 1.5; }

/* ─── Process ─── */
.sv-process { background: #fff; }
.sv-process-grid { display: flex; align-items: flex-start; justify-content: center; gap: 0; }
.sv-process-step { text-align: center; max-width: 200px; }
.sv-step-num { font-family: Georgia, serif; font-size: 2rem; font-weight: 700; color: #2563eb; margin-bottom: 12px; opacity: 0.6; }
.sv-process-step h3 { font-size: 1rem; font-weight: 600; color: #0f172a; margin: 0 0 6px; }
.sv-process-step p { font-size: 0.85rem; color: #64748b; line-height: 1.55; margin: 0; }
.sv-process-connector { display: flex; align-items: center; padding: 28px 8px 0; }

/* ─── Use Case / Before-After ─── */
.sv-usecase { background: #f8fafc; text-align: left; }
.sv-usecase h2 { text-align: left; }
.sv-usecase-layout { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; }
.sv-usecase-before, .sv-usecase-after { padding: 32px; border-radius: 14px; }
.sv-usecase-before { background: #fff; border: 1px solid #e2e8f0; }
.sv-usecase-after { background: #eff6ff; border: 1px solid #bfdbfe; }
.sv-uc-label { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 16px; padding: 4px 12px; border-radius: 6px; display: inline-block; }
.sv-uc-before-label { background: #f1f5f9; color: #64748b; }
.sv-uc-after-label { background: #dbeafe; color: #2563eb; }
.sv-usecase-before ul, .sv-usecase-after ul { list-style: none; padding: 0; margin: 0; }
.sv-usecase-before li, .sv-usecase-after li { font-size: 0.9rem; color: #475569; line-height: 1.55; padding: 6px 0; border-bottom: 1px solid #f1f5f9; }
.sv-usecase-before li:last-child, .sv-usecase-after li:last-child { border-bottom: none; font-weight: 600; color: #0f172a; }
.sv-usecase-after li:last-child { color: #2563eb; }
.sv-usecase-arrow { display: flex; align-items: center; justify-content: center; }

/* ─── Tools ─── */
.sv-tools { padding: 56px 24px; background: #fff; text-align: center; border-top: 1px solid #f1f5f9; }
.sv-tools-grid { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 20px; }
.sv-tool-badge { font-size: 0.85rem; color: #475569; background: #f8fafc; padding: 10px 20px; border-radius: 100px; border: 1px solid #e2e8f0; font-weight: 500; }

/* ─── CTA ─── */
.sv-cta { padding: 96px 24px; background: #0f172a; text-align: center; }
.sv-cta-inner { max-width: 540px; margin: 0 auto; }
.sv-cta-label { display: inline-block; font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: #60a5fa; margin-bottom: 16px; }
.sv-cta h2 { font-family: Georgia, serif; font-size: 2.2rem; font-weight: 700; color: #fff; margin: 0 0 14px; letter-spacing: -0.02em; }
.sv-cta p { font-size: 1.02rem; color: #94a3b8; line-height: 1.65; margin: 0 0 28px; }
.sv-cta-reassurance { font-size: 0.82rem; color: #475569; margin-top: 16px; }

/* ─── Checklist section ─── */
.sv-checklist { text-align: left; }
.sv-checklist-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.sv-check-item { display: flex; gap: 12px; align-items: flex-start; padding: 20px; background: #fff; border-radius: 10px; border: 1px solid #e2e8f0; }
.sv-check-icon { flex-shrink: 0; width: 28px; height: 28px; background: #eff6ff; border-radius: 8px; display: flex; align-items: center; justify-content: center; margin-top: 2px; }
.sv-check-item h4 { font-size: 0.95rem; font-weight: 600; color: #0f172a; margin: 0 0 4px; }
.sv-check-item p { font-size: 0.85rem; color: #64748b; line-height: 1.5; margin: 0; }

/* ─── Responsive ─── */
@media (max-width: 768px) {
    .sv-hero { padding: 120px 20px 56px; }
    .sv-hero h1 { font-size: 2.2rem; }
    .sv-hero h1 br, .sv-section h2 br { display: none; }
    .sv-section h2 { font-size: 1.7rem; }
    .sv-section { padding: 64px 20px; }
    .sv-problem-grid, .sv-features-grid, .sv-checklist-grid { grid-template-columns: 1fr; }
    .sv-feature-highlight { grid-column: span 1; }
    .sv-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .sv-process-grid { flex-direction: column; align-items: center; gap: 24px; }
    .sv-process-connector { display: none; }
    .sv-process-step { max-width: 100%; }
    .sv-usecase-layout { grid-template-columns: 1fr; }
    .sv-usecase-arrow { transform: rotate(90deg); }
    .sv-hero-actions { flex-direction: column; align-items: center; }
    .sv-hero-proof { flex-direction: column; gap: 12px; }
    .sv-proof-divider { width: 40px; height: 1px; }
    .sv-cta { padding: 64px 20px; }
    .sv-cta h2 { font-size: 1.6rem; }
}
