/* =========================================
   Service Provider V2 Element Styles
   Matches Kadence Element 2306977 design
   ========================================= */

/* Variables (Kadence palette) */
:root {
    --spv2-red: var(--global-palette1, #e00);
    --spv2-dark: var(--global-palette3, #1a1a2e);
    --spv2-light: var(--global-palette9, #ffffff);
    --spv2-gray-bg: var(--global-palette7, #f0f0f0);
    --spv2-gray-border: var(--global-palette6, #e0e0e0);
    --spv2-accent: var(--global-palette8, #f5f5f5);
}

/* ─── HERO ─── */
.spv2-hero { width:100vw; margin-left:calc(-50vw + 50%); background:#050000; }
.spv2-hero-inner { max-width:1290px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; min-height:500px; align-items:center; }
.spv2-hero-logo { background-size:contain; background-position:center; background-repeat:no-repeat; min-height:400px; }
.spv2-hero-content { padding:2rem 3rem; }
.spv2-hero-overline { color:var(--spv2-red); text-transform:uppercase; font-size:1rem; margin-bottom:.5rem; }
.spv2-hero-title { color:var(--spv2-light); font-size:2.5rem; line-height:1.2; margin:0 0 .5rem; }
.spv2-hero-tagline { color:var(--spv2-light); font-size:1.1rem; margin-bottom:1.5rem; }

/* Buttons */
.spv2-btn { display:inline-block; padding:14px 28px; text-decoration:none; font-weight:600; text-align:center; border-radius:4px; transition:all .2s; cursor:pointer; font-size:1rem; }
.spv2-btn-primary { background:var(--spv2-red); color:#fff; border:2px solid var(--spv2-red); }
.spv2-btn-primary:hover { background:#000; color:#fff; }
.spv2-btn-red { background:#ff0000; color:#fff; }
.spv2-btn-red:hover { background:#030000; color:#fff; }
.spv2-btn-outline { border:2px solid var(--spv2-red); color:var(--spv2-dark); background:transparent; }
.spv2-btn-outline:hover { background:var(--spv2-red); color:#fff; }
.spv2-btn-white { border:2px solid var(--spv2-red); color:var(--spv2-light); background:transparent; }
.spv2-btn-white:hover { background:var(--spv2-light); color:var(--spv2-dark); }
.spv2-btn-full { display:block; width:100%; box-sizing:border-box; }

/* ─── TABS ─── */
.spv2-tabs-section { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-light); }
.spv2-tabs-nav { max-width:1290px; margin:0 auto; display:flex; gap:1rem; padding:1rem 0 0; border-bottom:1px solid var(--spv2-red); }
.spv2-tab-btn { background:#000102; color:var(--spv2-light); border:none; padding:10px 24px; cursor:pointer; font-size:1rem; border-bottom:4px solid transparent; transition:all .2s; }
.spv2-tab-btn.active, .spv2-tab-btn:hover { background:#020000; border-bottom-color:var(--spv2-red); }
.spv2-tabs-content { max-width:1290px; margin:0 auto; }
.spv2-tab-pane { display:none; padding:2rem 0; }
.spv2-tab-pane.active { display:block; }

.spv2-overview-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.spv2-overview-photo img { width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:0; }
.spv2-overview-text h2 { font-size:1.8rem; line-height:1.2; margin-bottom:1rem; }

.spv2-coverage-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.spv2-coverage-map { min-height:300px; }
.spv2-coverage-text h3 { font-size:1.8rem; line-height:1.2; margin-bottom:1rem; }

/* ─── SERVICES GRID ─── */
.spv2-services { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-light); padding:3rem 0; }
.spv2-services-header { max-width:1290px; margin:0 auto; display:grid; grid-template-columns:1fr 2fr; gap:4rem; }
.spv2-services-text h2 { font-size:1.8rem; line-height:1.2; margin:0 0 .5rem; }
.spv2-services-text .spv2-overline { color:var(--spv2-red); text-transform:uppercase; font-size:.9rem; margin-bottom:.5rem; }
.spv2-services-grid { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.spv2-service-card { background:var(--spv2-accent); }
.spv2-service-card-img img { width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.spv2-service-card-body { padding:1rem; background:var(--spv2-light); }
.spv2-service-card-body h5 { margin:0 0 .5rem; font-size:1.1rem; }
.spv2-service-card-body p { margin:0; font-size:.95rem; color:var(--spv2-dark); }

/* ─── SEO ARTICLE ─── */
.spv2-seo-article { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-accent); }
.spv2-seo-inner { max-width:1290px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr; gap:2rem; padding:2rem 0; }
.spv2-seo-inner h2 { font-size:1.5rem; line-height:1.2; }
.spv2-seo-inner p { font-size:1rem; line-height:1.7; }

/* ─── CTA ─── */
.spv2-cta { width:100vw; margin-left:calc(-50vw + 50%); background-size:cover; background-position:center; min-height:450px; position:relative; }
.spv2-cta-overlay { background:rgba(0,0,0,0.8); min-height:450px; display:flex; align-items:center; justify-content:center; }
.spv2-cta-inner { max-width:850px; padding:2rem; text-align:center; }
.spv2-cta-inner h2 { color:#fdffff; font-size:1.8rem; line-height:1.2; margin-bottom:1rem; }
.spv2-cta-inner p { color:#fdffff; font-size:1rem; margin-bottom:1.5rem; }

/* ─── FEATURES (photo + title + desc + bullets) ─── */
.spv2-features { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-light); padding:3rem 0; }
.spv2-features-header { text-align:center; margin-bottom:2rem; }
.spv2-features-header h2 { font-size:1.8rem; line-height:1.2; max-width:800px; margin:0 auto; }
.spv2-overline-red { color:#f80404; font-weight:700; text-transform:uppercase; font-size:1rem; margin:0 0 .5rem; }
.spv2-feature-row { max-width:1290px; margin:0 auto 2rem; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; padding:1.5rem; }
.spv2-feature-row.spv2-feature-reverse { direction:rtl; }
.spv2-feature-row.spv2-feature-reverse > * { direction:ltr; }
.spv2-feature-photo { background:var(--spv2-gray-bg); border-radius:24px; overflow:hidden; padding:1rem; }
.spv2-feature-photo img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:12px; }
.spv2-feature-content h3 { font-size:1.5rem; line-height:1; margin:0 0 1rem; }
.spv2-feature-content p { margin:0 0 1rem; }
.spv2-bullet-list { list-style:none; padding:0; margin:0; }
.spv2-bullet-list li { padding:6px 0 6px 36px; position:relative; font-weight:700; font-size:1.05rem; }
.spv2-bullet-list li::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:26px; height:26px; background:var(--spv2-red); border-radius:50%; }
.spv2-bullet-list li::after { content:'\2713'; position:absolute; left:5px; top:50%; transform:translateY(-50%); color:#fff; font-size:14px; font-weight:bold; }

/* ─── PRICING ─── */
.spv2-pricing-section { max-width:1290px; margin:0 auto; }
.spv2-pricing-header { text-align:center; margin-bottom:1.5rem; }
.spv2-pricing-header h2 { font-size:1.5rem; }
.spv2-pricing-header p { max-width:750px; margin:0 auto; }
.spv2-pricing-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:0; }
.spv2-pricing-card { padding:2rem 1.5rem; text-align:center; border:2px solid var(--spv2-gray-border); }
.spv2-pricing-card.spv2-pricing-featured { background:var(--spv2-dark); color:var(--spv2-light); border-color:var(--spv2-dark); }
.spv2-pricing-label { text-transform:uppercase; font-weight:700; font-size:.9rem; margin-bottom:.5rem; }
.spv2-pricing-amount { font-size:2.5rem; font-weight:700; line-height:1; margin-bottom:1rem; }
.spv2-pricing-desc { font-size:.95rem; margin-bottom:1.5rem; }
.spv2-pricing-featured .spv2-pricing-label,
.spv2-pricing-featured .spv2-pricing-amount,
.spv2-pricing-featured .spv2-pricing-desc { color:var(--spv2-light); }

/* ─── REVIEWS ─── */
.spv2-reviews { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-red); padding:3rem 0; }
.spv2-reviews-inner { text-align:center; max-width:900px; margin:0 auto 2rem; }
.spv2-reviews-inner h2 { color:var(--spv2-light); font-size:1.8rem; }
.spv2-reviews-headline { color:var(--spv2-light); font-size:1.1rem; }
.spv2-reviews-grid { max-width:1290px; margin:0 auto; display:grid; grid-template-columns:repeat(3, 1fr); gap:1rem; }
.spv2-review-card { background:var(--spv2-light); border-radius:16px; padding:1.5rem; }
.spv2-review-quote-icon { font-size:3rem; color:rgba(238,242,245,0.5); margin-bottom:-2.5rem; }
.spv2-review-text { font-size:1rem; margin-bottom:1rem; min-height:80px; }
.spv2-review-divider { border-bottom:1px solid var(--spv2-gray-bg); margin-bottom:1rem; }
.spv2-review-author { font-weight:600; }

/* ─── STATS ─── */
.spv2-stats { width:100vw; margin-left:calc(-50vw + 50%); background:#000305; display:grid; grid-template-columns:1fr 1fr; max-width:100vw; }
.spv2-stat { text-align:center; padding:3rem 2rem; }
.spv2-stat-number { color:var(--spv2-red); font-size:3rem; font-weight:700; }
.spv2-stat-label { color:var(--spv2-light); text-transform:capitalize; font-size:1.1rem; margin-top:.5rem; }

/* ─── FAQ ─── */
.spv2-faq { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-accent); padding:3rem 0; background:linear-gradient(ellipse at center bottom, var(--spv2-light) 0%, var(--spv2-gray-bg) 100%); }
.spv2-faq-header { max-width:1290px; margin:0 auto 2rem; display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.spv2-faq-header h2 { font-size:1.5rem; }
.spv2-faq-header p { font-weight:300; }
.spv2-faq-list { max-width:1290px; margin:0 auto; columns:2; column-gap:2rem; }
.spv2-faq-item { break-inside:avoid; margin-bottom:.5rem; border-bottom:1px solid var(--spv2-gray-border); }
.spv2-faq-question { display:flex; justify-content:space-between; align-items:center; width:100%; background:none; border:none; padding:14px 0; cursor:pointer; font-size:1rem; text-align:left; color:var(--spv2-dark); }
.spv2-faq-icon { font-size:1.5rem; transition:transform .2s; }
.spv2-faq-item.open .spv2-faq-icon { transform:rotate(45deg); }
.spv2-faq-answer { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.spv2-faq-item.open .spv2-faq-answer { max-height:500px; }
.spv2-faq-answer p { padding:0 0 1rem; }

/* ─── FOOTER CTA ─── */
.spv2-footer-cta { width:100vw; margin-left:calc(-50vw + 50%); background:#000308; padding:3rem 0; text-align:center; }
.spv2-footer-cta-inner { max-width:1000px; margin:0 auto; }
.spv2-footer-cta-inner h6 { color:var(--spv2-red); text-transform:uppercase; font-size:.9rem; margin-bottom:.5rem; }
.spv2-footer-cta-inner h2 { color:var(--spv2-light); font-size:1.8rem; line-height:1.2; margin-bottom:1rem; }
.spv2-footer-cta-inner p { color:var(--spv2-light); max-width:700px; margin:0 auto; }

/* ─── LOGOS ─── */
.spv2-logos { width:100vw; margin-left:calc(-50vw + 50%); background:var(--spv2-light); padding:1.5rem 0; overflow:hidden; }
.spv2-logos-track { display:flex; gap:5rem; animation:spv2-scroll 25s linear infinite; width:max-content; align-items:center; }
.spv2-logos-track img { height:60px; width:auto; opacity:.7; filter:grayscale(50%); }
@keyframes spv2-scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ─── MOBILE ─── */
@media (max-width:768px) {
    .spv2-hero-inner { grid-template-columns:1fr; }
    .spv2-hero-logo { min-height:250px; }
    .spv2-hero-content { padding:1.5rem; }
    .spv2-hero-title { font-size:1.8rem; }
    .spv2-tabs-nav { flex-wrap:wrap; padding:.5rem; }
    .spv2-tab-btn { flex:1; min-width:calc(50% - .5rem); font-size:.85rem; padding:8px 12px; }
    .spv2-overview-grid,
    .spv2-coverage-grid { grid-template-columns:1fr; gap:1.5rem; }
    .spv2-services-header { grid-template-columns:1fr; gap:1.5rem; }
    .spv2-services-grid { grid-template-columns:1fr; }
    .spv2-feature-row,
    .spv2-feature-row.spv2-feature-reverse { grid-template-columns:1fr; direction:ltr; gap:1.5rem; padding:1rem; }
    .spv2-pricing-grid { grid-template-columns:1fr; }
    .spv2-reviews-grid { grid-template-columns:1fr; }
    .spv2-stats { grid-template-columns:1fr; }
    .spv2-faq-header { grid-template-columns:1fr; }
    .spv2-faq-list { columns:1; }
    .spv2-seo-inner { grid-template-columns:1fr; }
}
