/*
Theme Name: SPS Lite
Theme URI: https://swimmingpoolshop.co.za/
Author: Gauteng Safety Pool Covers
Description: Fast dark WooCommerce theme for Swimming Pool Shop.
Version: 2.1.0
Text Domain: sps-lite
*/
:root{--sps-purple:#6a2383;--sps-grey:#444b53;--sps-lime:#93ce3d;--sps-neon-blue:#00cfff;--sps-dark:#0b0d12;--sps-dark-2:#111418;--sps-panel:#171b23;--sps-panel-2:#202633;--sps-text:#f5f7fa;--sps-muted:#a9b0bc;--sps-line:rgba(255,255,255,.12);--sps-purple-glow:rgba(106,35,131,.42);--sps-blue-glow:rgba(0,207,255,.28);--orange:#ffb347;--danger:#ff6b6b;--radius:22px;--shadow:0 22px 60px rgba(0,0,0,.38);--bg:var(--sps-dark);--bg2:var(--sps-dark-2);--panel:var(--sps-panel);--panel2:var(--sps-panel-2);--text:var(--sps-text);--muted:var(--sps-muted);--line:var(--sps-line);--blue:var(--sps-purple);--cyan:var(--sps-neon-blue);--lime:var(--sps-lime)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at 12% 0%,rgba(106,35,131,.34),transparent 36%),radial-gradient(circle at 88% 10%,rgba(0,207,255,.14),transparent 30%),linear-gradient(180deg,var(--sps-dark),#07080c 76%);color:var(--sps-text);font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;border-radius:16px}.wrap{width:min(1180px,calc(100% - 34px));margin-inline:auto}.narrow{width:min(860px,calc(100% - 34px))}.panel{background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.03));border:1px solid var(--sps-line);border-radius:var(--radius);box-shadow:var(--shadow)}
.site-header{position:sticky;top:0;z-index:50;background:rgba(11,13,18,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(0,207,255,.18);box-shadow:0 0 22px rgba(0,207,255,.08)}.header-inner{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;align-items:center;gap:12px;font-weight:900}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,var(--sps-purple),#8a2fab 58%,var(--sps-neon-blue));color:#fff;box-shadow:0 0 18px var(--sps-purple-glow),0 0 14px var(--sps-blue-glow)}.brand-text{font-size:1.05rem}.custom-logo{max-height:58px;width:auto}.main-nav ul{display:flex;gap:18px;list-style:none;margin:0;padding:0}.main-nav a{color:var(--sps-muted);font-weight:650}.main-nav a:hover{color:#fff;text-shadow:0 0 12px var(--sps-blue-glow)}.header-actions{display:flex;align-items:center;gap:10px}.mini-link{color:var(--sps-muted);font-weight:700}.mini-link:hover{color:var(--sps-neon-blue)}.cart-pill{display:flex;gap:8px;align-items:center;padding:9px 12px;border-radius:999px;background:rgba(106,35,131,.22);border:1px solid rgba(0,207,255,.22)}.cart-count{display:inline-grid;place-items:center;min-width:22px;height:22px;border-radius:999px;background:var(--sps-lime);color:#071008;font-weight:900;font-size:.78rem}
.hero{padding:78px 0 46px}.hero-grid{display:grid;grid-template-columns:1.45fr .75fr;gap:28px;align-items:center}.eyebrow{margin:0 0 12px;color:var(--sps-neon-blue);text-transform:uppercase;letter-spacing:.12em;font-weight:850;font-size:.78rem}.hero h1{font-size:clamp(2.35rem,5vw,5.4rem);line-height:.94;margin:0 0 20px;letter-spacing:-.06em}.lead{font-size:1.22rem;color:var(--sps-muted);max-width:760px}.hero-actions,.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}.btn,.button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 18px;border-radius:999px;border:1px solid rgba(0,207,255,.22);font-weight:850;cursor:pointer;transition:all .22s ease}.btn.primary,.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{background:linear-gradient(135deg,var(--sps-purple),#7f2aa0);color:#fff;border:0;box-shadow:0 0 18px var(--sps-purple-glow)}.btn.primary:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,.woocommerce input.button.alt:hover{background:var(--sps-neon-blue);color:#071018;box-shadow:0 0 20px var(--sps-blue-glow);transform:translateY(-1px)}.btn.lime{background:var(--sps-lime);color:#071008;border:0}.btn.lime:hover{filter:brightness(1.07);box-shadow:0 0 18px rgba(147,206,61,.22)}.btn.ghost{background:rgba(255,255,255,.07);color:#fff}.btn.ghost:hover{border-color:var(--sps-neon-blue);box-shadow:0 0 16px var(--sps-blue-glow)}.hero-card{padding:28px;border-color:rgba(0,207,255,.2);box-shadow:var(--shadow),0 0 28px rgba(0,207,255,.09)}.hero-card h2{margin-top:0;font-size:1.8rem}.hero-card p{color:var(--sps-muted)}
.section{padding:44px 0}.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:18px}.section h2,.section-head h2{font-size:clamp(1.7rem,3vw,3rem);line-height:1;margin:0}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.cat-card{padding:22px;min-height:176px;display:flex;flex-direction:column;justify-content:space-between;transition:.18s transform,.18s border-color,.18s box-shadow;background:linear-gradient(180deg,rgba(106,35,131,.18),rgba(255,255,255,.025))}.cat-card:hover{transform:translateY(-3px);border-color:rgba(0,207,255,.52);box-shadow:0 18px 50px rgba(0,0,0,.34),0 0 18px var(--sps-blue-glow)}.cat-card h3{font-size:1.35rem;margin:0 0 8px}.cat-card p{color:var(--sps-muted);margin:0 0 18px}.cat-card span{color:var(--sps-neon-blue);font-weight:900}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.feature{padding:28px}.feature p{color:var(--sps-muted)}
.page-main{padding:42px 0 70px}.content-panel{padding:34px}.entry-content{color:#d9e1ea}.entry-content h2{color:#fff;margin-top:34px}.entry-content a{color:var(--sps-neon-blue);font-weight:800}.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.post-card{padding:22px}.post-card p{color:var(--sps-muted)}
.shop-main{padding:34px 0 70px}.shop-layout{display:grid;grid-template-columns:280px 1fr;gap:18px}.shop-content{padding:24px;min-width:0}.shop-sidebar{display:flex;flex-direction:column;gap:14px}.widget{padding:18px}.widget-title{margin:0 0 12px}.woocommerce-breadcrumb{color:var(--sps-muted);font-size:.9rem;margin-bottom:18px}.woocommerce-products-header__title,.product_title{font-size:clamp(2rem,4vw,3.8rem);line-height:1;margin:0 0 18px}.woocommerce-result-count,.woocommerce-ordering{color:var(--sps-muted)}.woocommerce-ordering select,.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,input,select,textarea{background:#0d1017;color:#fff;border:1px solid var(--sps-line);border-radius:14px;padding:12px}.woocommerce-ordering select:focus,.woocommerce form .form-row input.input-text:focus,.woocommerce form .form-row textarea:focus,input:focus,select:focus,textarea:focus{outline:none;border-color:var(--sps-neon-blue);box-shadow:0 0 0 3px rgba(0,207,255,.12)}.products{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;list-style:none;padding:0;margin:22px 0!important}.products::before,.products::after{display:none!important}.woocommerce ul.products li.product{width:auto!important;margin:0!important;float:none!important;background:linear-gradient(180deg,rgba(106,35,131,.16),rgba(255,255,255,.03));border:1px solid var(--sps-line);border-radius:20px;padding:14px!important;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:100%;transition:all .2s ease}.woocommerce ul.products li.product:hover{transform:translateY(-3px);border-color:rgba(0,207,255,.46);box-shadow:0 22px 60px rgba(0,0,0,.42),0 0 18px rgba(0,207,255,.18)}.woocommerce ul.products li.product a img{margin:0 0 12px!important;aspect-ratio:1/1;object-fit:cover;background:#fff}.woocommerce-loop-product__title{font-size:1rem!important;color:#fff;min-height:48px}.price{color:var(--sps-lime)!important;font-weight:950!important;font-size:1rem!important}.woocommerce span.onsale{background:var(--sps-neon-blue);color:#071018;border-radius:999px;min-height:auto;line-height:1;padding:8px 10px;font-weight:900;box-shadow:0 0 12px var(--sps-blue-glow)}.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:28px}.woocommerce div.product div.images,.woocommerce div.product div.summary{width:auto!important;float:none!important}.woocommerce div.product .summary{padding:8px}.woocommerce-product-details__short-description{color:var(--sps-muted);font-size:1.05rem}.quantity .qty{width:82px}.single_add_to_cart_button{background:linear-gradient(135deg,var(--sps-purple),#7f2aa0)!important;color:#fff!important}.single_add_to_cart_button:hover{background:var(--sps-neon-blue)!important;color:#071018!important}.woocommerce-tabs,.related.products{grid-column:1/-1}.woocommerce-tabs ul.tabs{display:flex;gap:8px;list-style:none;padding:0;margin:30px 0 0;border-bottom:1px solid var(--sps-line)}.woocommerce-tabs ul.tabs li{padding:12px 16px;border:1px solid var(--sps-line);border-bottom:0;border-radius:14px 14px 0 0}.woocommerce-tabs ul.tabs li.active{border-color:rgba(0,207,255,.42);box-shadow:0 -8px 18px rgba(0,207,255,.08)}.woocommerce-tabs .panel{padding:22px;border-top-left-radius:0}.woocommerce-message,.woocommerce-info,.woocommerce-error{background:rgba(0,207,255,.11);border:1px solid rgba(0,207,255,.3);border-radius:16px;color:#fff;padding:16px;list-style:none}.woocommerce-message{background:rgba(147,206,61,.12);border-color:rgba(147,206,61,.3)}.woocommerce-error{background:rgba(255,107,107,.12);border-color:rgba(255,107,107,.35)}.woocommerce-cart-form table,.woocommerce-checkout-review-order-table{width:100%;border-collapse:collapse}.woocommerce-cart-form th,.woocommerce-cart-form td,.woocommerce-checkout-review-order-table th,.woocommerce-checkout-review-order-table td{border-bottom:1px solid var(--sps-line);padding:12px;text-align:left}.cart_totals,.woocommerce-checkout .col2-set,.woocommerce-checkout-review-order{background:rgba(255,255,255,.04);border:1px solid var(--sps-line);border-radius:20px;padding:20px;margin-top:18px}.woocommerce form .form-row label{display:block;font-weight:800;margin-bottom:6px}.woocommerce form .form-row{margin-bottom:14px}.site-footer{border-top:1px solid rgba(0,207,255,.18);background:#07080c;padding:34px 0;color:var(--sps-muted)}.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:18px}.footer-grid strong{color:#fff}.footer-grid a:hover{color:var(--sps-neon-blue)}.footer-grid ul{list-style:none;margin:8px 0 0;padding:0}.footer-bottom{border-top:1px solid var(--sps-line);padding-top:18px;margin-top:22px;font-size:.9rem}
@media(max-width:900px){.header-inner{flex-wrap:wrap;padding:12px 0}.main-nav{order:3;width:100%;overflow:auto}.main-nav ul{min-width:max-content}.hero-grid,.split,.woocommerce div.product{grid-template-columns:1fr}.card-grid,.products,.post-grid{grid-template-columns:repeat(2,1fr)}.shop-layout{grid-template-columns:1fr}.shop-sidebar{order:2}.footer-grid{grid-template-columns:1fr}.mini-link{display:none}}
@media(max-width:560px){.card-grid,.products,.post-grid{grid-template-columns:1fr}.hero{padding-top:42px}.hero h1{font-size:2.5rem}.section-head{display:block}.content-panel,.shop-content{padding:18px}.header-actions{width:100%;justify-content:space-between}}

/* SPS Pro WooCommerce additions */
.menu-toggle{display:none;background:rgba(255,255,255,.06);border:1px solid rgba(0,207,255,.24);color:#fff;border-radius:12px;padding:10px 13px;font-weight:900}.text-link{color:var(--sps-neon-blue);font-weight:900}.neon-card{position:relative;overflow:hidden}.neon-card:before{content:"";position:absolute;inset:-80px -80px auto auto;width:190px;height:190px;background:radial-gradient(circle,rgba(0,207,255,.28),transparent 65%);pointer-events:none}.tick-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:8px}.tick-list li:before{content:"✓";color:var(--sps-lime);font-weight:900;margin-right:8px}.trust-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;overflow:hidden;padding:0;background:rgba(255,255,255,.055)}.trust-strip div{padding:18px;background:rgba(11,13,18,.72)}.trust-strip strong{display:block;color:#fff}.trust-strip span{display:block;color:var(--sps-muted);font-size:.92rem;margin-top:4px}.cta-band{padding:32px;display:flex;align-items:center;justify-content:space-between;gap:22px;background:linear-gradient(135deg,rgba(106,35,131,.28),rgba(0,207,255,.08))}.cta-band h2{margin:0 0 8px}.cta-band p{color:var(--sps-muted);margin:0}.product-help{padding:14px;margin:18px 0;display:grid;gap:6px;border-color:rgba(0,207,255,.22)}.product-help strong{color:#fff}.product-help span{color:var(--sps-muted)}.product-help a{color:var(--sps-neon-blue);font-weight:900}.woocommerce div.product form.cart{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:20px 0}.woocommerce div.product p.price{font-size:1.7rem!important}.woocommerce .woocommerce-tabs h2{font-size:1.5rem}.woocommerce table.shop_table{background:rgba(255,255,255,.03);border:1px solid var(--sps-line);border-radius:18px;overflow:hidden}.woocommerce table.shop_table th{color:#fff}.woocommerce table.shop_table td{color:#dce6ef}.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{width:100%;text-align:center}.woocommerce-checkout #payment{background:rgba(255,255,255,.04);border:1px solid var(--sps-line);border-radius:20px;padding:18px}.woocommerce-checkout #payment ul.payment_methods{list-style:none;padding:0;margin:0}.woocommerce-checkout #payment div.payment_box{background:rgba(0,207,255,.08);border:1px solid rgba(0,207,255,.16);border-radius:14px;padding:12px;margin:12px 0}.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;padding:0;display:grid;gap:8px}.woocommerce-account .woocommerce-MyAccount-navigation a{display:block;padding:12px 14px;background:rgba(255,255,255,.05);border:1px solid var(--sps-line);border-radius:14px}.woocommerce-account .woocommerce-MyAccount-navigation a:hover{border-color:var(--sps-neon-blue)}.wc-block-components-notice-banner{background:rgba(0,207,255,.1)!important;border:1px solid rgba(0,207,255,.25)!important;color:#fff!important;border-radius:16px!important}.wp-block-search__inside-wrapper{display:flex;gap:8px}.wp-block-search__button{background:var(--sps-purple);color:#fff;border:0;border-radius:12px;padding:10px 14px;font-weight:900}.widget ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}.widget a{color:var(--sps-muted)}.widget a:hover{color:var(--sps-neon-blue)}
@media(max-width:900px){.menu-toggle{display:inline-flex}.main-nav{display:none}.main-nav.is-open{display:block}.trust-strip{grid-template-columns:repeat(2,1fr)}.cta-band{display:block}.cta-band .btn{margin-top:18px}}
@media(max-width:560px){.trust-strip{grid-template-columns:1fr}.header-inner{gap:10px}.brand-text{font-size:.95rem}.cart-pill{padding:8px 10px}}

/* SPS contact / quote form */
.sps-contact-wrap{margin:34px 0}.sps-contact-card{display:grid;grid-template-columns:0.9fr 1.1fr;gap:28px;align-items:start;border:1px solid rgba(0,207,255,.18);box-shadow:0 0 30px rgba(0,207,255,.08),var(--shadow)}.sps-contact-intro h2{margin:8px 0 10px}.contact-methods{display:grid;gap:10px;margin-top:20px}.contact-methods a{display:block;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.04);color:var(--sps-text);text-decoration:none}.contact-methods a:hover{border-color:var(--sps-neon-blue);box-shadow:0 0 16px rgba(0,207,255,.18)}.sps-contact-form{display:grid;gap:16px}.form-grid.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.sps-contact-form label{display:grid;gap:7px;color:var(--sps-text);font-weight:700}.sps-contact-form input,.sps-contact-form select,.sps-contact-form textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:#0f131a;color:var(--sps-text);padding:13px 14px;outline:none}.sps-contact-form input:focus,.sps-contact-form select:focus,.sps-contact-form textarea:focus{border-color:var(--sps-neon-blue);box-shadow:0 0 0 4px rgba(0,207,255,.12)}.form-small{color:var(--sps-muted);font-size:.92rem}.hidden-field{position:absolute;left:-9999px}.form-notice{padding:14px 16px;border-radius:16px;margin-bottom:16px}.form-notice.success{background:rgba(147,206,61,.12);border:1px solid rgba(147,206,61,.38)}.form-notice.error{background:rgba(255,107,107,.12);border:1px solid rgba(255,107,107,.38)}@media(max-width:780px){.sps-contact-card,.form-grid.two{grid-template-columns:1fr}}

/* SPS built-in logo + favicon assets */
.sps-header-logo{display:block;max-height:58px;width:auto;max-width:310px;border-radius:0;object-fit:contain;filter:drop-shadow(0 0 12px rgba(0,207,255,.13))}.brand .custom-logo{border-radius:0;filter:drop-shadow(0 0 12px rgba(0,207,255,.13))}@media(max-width:560px){.sps-header-logo{max-width:205px;max-height:48px}.brand{min-width:0}}


/* SPS_PRODUCT_GALLERY_FIX_V2 START */
/*
 * Compact single-product presentation for normal shop items.
 * The summary receives the available width while the image stage stays sensible.
 */
body.single-product .shop-layout {
  grid-template-columns: minmax(0, 1fr);
}

body.single-product .shop-content {
  width: 100%;
  min-width: 0;
  padding: 24px;
}

body.single-product .shop-content div.product {
  display: grid !important;
  grid-template-columns: minmax(300px, 390px) minmax(0, 1fr) !important;
  gap: 34px !important;
  align-items: start !important;
}

body.single-product .shop-content div.product div.images,
body.single-product .shop-content div.product div.summary {
  width: auto !important;
  float: none !important;
  min-width: 0 !important;
  margin: 0 !important;
}

body.single-product .shop-content div.product div.images {
  max-width: 390px !important;
}

body.single-product .shop-content div.product div.images img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1;
  object-fit: contain !important;
  padding: 18px !important;
  background: #ffffff !important;
  border-radius: 18px !important;
}

body.single-product .shop-content .product_title {
  max-width: none !important;
  font-size: clamp(2rem, 4vw, 3.2rem) !important;
  line-height: 1.05 !important;
  overflow-wrap: anywhere;
}

body.admin-bar .site-header {
  top: 32px;
}

@media screen and (max-width: 900px) {
  body.single-product .shop-content div.product {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 22px !important;
  }

  body.single-product .shop-content div.product div.images {
    width: min(100%, 390px) !important;
    margin-inline: auto !important;
  }

  body.single-product .shop-content {
    padding: 18px;
  }
}

@media screen and (max-width: 782px) {
  body.admin-bar .site-header {
    top: 46px;
  }
}
/* SPS_PRODUCT_GALLERY_FIX_V2 END */

/* ============================================================
   SPS ABOUT PAGE START
   Scoped styles for /about-us/
   ============================================================ */

.sps-about {
  --sps-bg: #0b1020;
  --sps-panel: rgba(17, 24, 46, 0.88);
  --sps-panel-soft: rgba(25, 34, 62, 0.72);
  --sps-purple: #8b5cf6;
  --sps-blue: #27d3ff;
  --sps-lime: #93ce3d;
  --sps-text: #f5f7ff;
  --sps-muted: #b9c2d9;
  --sps-line: rgba(139, 92, 246, 0.34);

  color: var(--sps-text);
  background:
    radial-gradient(circle at 5% 0%, rgba(39, 211, 255, 0.12), transparent 32rem),
    radial-gradient(circle at 95% 15%, rgba(139, 92, 246, 0.18), transparent 34rem),
    var(--sps-bg);
  border-radius: 22px;
  margin: 18px auto 40px;
  max-width: 1240px;
  overflow: hidden;
}

.sps-about * {
  box-sizing: border-box;
}

.sps-about__hero,
.sps-about__section,
.sps-about__cta {
  padding: clamp(28px, 5vw, 72px);
}

.sps-about__hero {
  border-bottom: 1px solid var(--sps-line);
}

.sps-about__eyebrow {
  color: var(--sps-blue);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  margin: 0 0 12px;
  text-transform: uppercase;
}

.sps-about h1,
.sps-about h2,
.sps-about h3 {
  color: var(--sps-text);
  line-height: 1.12;
  margin-top: 0;
}

.sps-about h1 {
  font-size: clamp(2.1rem, 6vw, 4.8rem);
  margin-bottom: 16px;
  max-width: 900px;
}

.sps-about h2 {
  font-size: clamp(1.65rem, 4vw, 2.65rem);
  margin-bottom: 14px;
}

.sps-about h3 {
  color: var(--sps-blue);
  font-size: 1.08rem;
  margin-bottom: 8px;
}

.sps-about p,
.sps-about li {
  color: var(--sps-muted);
  font-size: 1rem;
  line-height: 1.75;
}

.sps-about__lead {
  font-size: clamp(1.08rem, 2.4vw, 1.26rem);
  max-width: 850px;
}

.sps-about__section {
  border-bottom: 1px solid var(--sps-line);
}

.sps-about__grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  margin-top: 28px;
}

.sps-about__card {
  background: linear-gradient(
    145deg,
    var(--sps-panel),
    var(--sps-panel-soft)
  );
  border: 1px solid var(--sps-line);
  border-radius: 18px;
  padding: 22px;
}

.sps-about__card p {
  margin-bottom: 0;
}

.sps-about__list {
  display: grid;
  gap: 10px;
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
}

.sps-about__list li {
  background: var(--sps-panel-soft);
  border-left: 3px solid var(--sps-blue);
  border-radius: 10px;
  padding: 12px 16px;
}

.sps-about__cta {
  background:
    linear-gradient(
      135deg,
      rgba(139, 92, 246, 0.28),
      rgba(39, 211, 255, 0.13)
    );
  text-align: center;
}

.sps-about__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 22px;
}

.sps-about__button {
  border: 1px solid var(--sps-blue);
  border-radius: 999px;
  color: var(--sps-text) !important;
  display: inline-block;
  font-weight: 800;
  padding: 13px 22px;
  text-decoration: none !important;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease;
}

.sps-about__button:hover,
.sps-about__button:focus {
  background: rgba(39, 211, 255, 0.16);
  box-shadow: 0 0 24px rgba(39, 211, 255, 0.26);
  transform: translateY(-2px);
}

.sps-about__button--primary {
  background: linear-gradient(135deg, var(--sps-purple), #5d55ff);
  border-color: transparent;
}

.sps-about__button--primary:hover,
.sps-about__button--primary:focus {
  background: linear-gradient(135deg, #9c73ff, #6860ff);
}

@media (max-width: 640px) {
  .sps-about {
    border-radius: 0;
    margin-top: 0;
  }

  .sps-about__hero,
  .sps-about__section,
  .sps-about__cta {
    padding: 28px 20px;
  }
}

/* SPS ABOUT PAGE END */


/* Swimming Pool Shop footer navigation — added by project maintenance */
.sps-footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem 1rem;
    margin-top: 1rem;
}

.sps-footer-links a {
    color: inherit;
    font-size: 0.92rem;
    text-decoration: none;
    opacity: 0.88;
    transition: opacity 160ms ease, transform 160ms ease;
}

.sps-footer-links a:hover,
.sps-footer-links a:focus-visible {
    opacity: 1;
    transform: translateY(-1px);
    text-decoration: underline;
    text-underline-offset: 0.2rem;
}

/* SPS CONTACT PAGE START */
.sps-contact-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 2.5rem 1.1rem 4rem;
}

.sps-contact-hero {
    padding: clamp(1.5rem, 4vw, 3rem);
    border: 1px solid rgba(0, 207, 255, 0.24);
    border-radius: 1.4rem;
    background:
        radial-gradient(circle at top right, rgba(0, 207, 255, 0.16), transparent 40%),
        linear-gradient(135deg, rgba(106, 35, 131, 0.34), rgba(11, 13, 18, 0.96));
    box-shadow: 0 0 2rem rgba(0, 207, 255, 0.09);
}

.sps-contact-kicker {
    margin: 0 0 0.6rem;
    color: var(--sps-neon-blue, #00cfff);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sps-contact-hero h1 {
    max-width: 760px;
    margin: 0;
    font-size: clamp(2rem, 5vw, 3.7rem);
    line-height: 1.04;
}

.sps-contact-hero p {
    max-width: 820px;
    margin: 1rem 0 0;
    line-height: 1.75;
    opacity: 0.9;
}

.sps-contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 1.2rem;
    margin-top: 1.3rem;
}

.sps-contact-card {
    padding: 1.25rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.15rem;
    background: rgba(23, 27, 35, 0.93);
}

.sps-contact-card h2,
.sps-contact-card h3 {
    margin-top: 0;
}

.sps-contact-card p,
.sps-contact-card li {
    line-height: 1.7;
    opacity: 0.9;
}

.sps-contact-card ul {
    padding-left: 1.2rem;
}

.sps-contact-methods {
    display: grid;
    gap: 0.85rem;
    margin-top: 1rem;
}

.sps-contact-method {
    display: block;
    padding: 1rem;
    border: 1px solid rgba(0, 207, 255, 0.18);
    border-radius: 0.9rem;
    background: rgba(11, 13, 18, 0.58);
    text-decoration: none;
}

.sps-contact-method strong,
.sps-contact-method span {
    display: block;
}

.sps-contact-method strong {
    color: var(--sps-neon-blue, #00cfff);
}

.sps-contact-form-shell {
    margin-top: 0.8rem;
}

.sps-contact-form {
    display: grid;
    gap: 1rem;
}

.sps-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.sps-contact-form label,
.sps-contact-form span {
    display: block;
}

.sps-contact-form span {
    margin-bottom: 0.35rem;
    font-size: 0.9rem;
    font-weight: 700;
}

.sps-contact-form input,
.sps-contact-form select,
.sps-contact-form textarea {
    width: 100%;
    box-sizing: border-box;
    padding: 0.8rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 0.7rem;
    background: rgba(11, 13, 18, 0.82);
    color: #fff;
    font: inherit;
}

.sps-contact-form input:focus,
.sps-contact-form select:focus,
.sps-contact-form textarea:focus {
    border-color: var(--sps-neon-blue, #00cfff);
    outline: 2px solid rgba(0, 207, 255, 0.2);
    outline-offset: 2px;
}

.sps-form-notice {
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    border-radius: 0.75rem;
}

.sps-form-notice-success {
    border: 1px solid rgba(147, 206, 61, 0.55);
    background: rgba(147, 206, 61, 0.12);
}

.sps-form-notice-error {
    border: 1px solid rgba(255, 130, 130, 0.55);
    background: rgba(255, 130, 130, 0.1);
}

.sps-honeypot {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

@media (max-width: 820px) {
    .sps-contact-layout,
    .sps-form-grid {
        grid-template-columns: 1fr;
    }
}
/* SPS CONTACT PAGE END */


/* SPS LANDING CONTACT START */
.sps-landing-contact-shell {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    gap: clamp(1.2rem, 3vw, 2.4rem);
    padding: clamp(1.2rem, 3vw, 2rem);
}

.sps-landing-contact-copy {
    align-self: start;
}

.sps-landing-contact-copy h2 {
    margin-top: 0;
}

.sps-landing-contact-copy p:not(.eyebrow) {
    color: rgba(255, 255, 255, 0.76);
}

@media (max-width: 820px) {
    .sps-landing-contact-shell {
        grid-template-columns: 1fr;
    }
}
/* SPS LANDING CONTACT END */