/*
Theme Name:  EcoShower
Theme URI:   https://www.ecoshower.com.au
Author:      EcoShower Australia
Description: Custom WooCommerce theme for E-Co Shower – The World's Best Water Saving Shower.
Version:     1.1.0
Requires at least: 6.0
Requires PHP: 8.0
License:     GNU General Public License v2 or later
Text Domain: ecoshower
*/

:root {
  --sky:#1a8fcc; --sky-dark:#0f6699; --sky-deeper:#0a4a73; --sky-light:#3aaee0;
  --sky-pale:#e8f6fc; --surf:#00c4b4; --ocean:#0a2e45;
  --white:#ffffff; --off-white:#f4fafd; --mid:#4a6b7a; --text:#1a3040;
  --border:#c2e2f0; --gold:#f0a500; --radius:6px; --trans:0.28s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito Sans','Segoe UI',sans-serif;background:var(--white);color:var(--text);line-height:1.65;overflow-x:hidden;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--sky);text-decoration:none;transition:color var(--trans);}
a:hover{color:var(--sky-dark);}
h1,h2,h3,h4,h5{font-family:'Playfair Display',Georgia,serif;line-height:1.2;color:var(--ocean);}
p{margin-bottom:1rem;}
ul{list-style:none;}
.container{max-width:1240px;margin:0 auto;padding:0 5%;}
section{padding:5rem 0;}
.eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--sky);margin-bottom:.6rem;display:block;}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;color:var(--ocean);margin-bottom:1rem;}
.section-desc{font-size:1rem;color:var(--mid);max-width:540px;line-height:1.8;margin-bottom:2rem;}
.text-center{text-align:center;}
.text-center .section-desc{margin-left:auto;margin-right:auto;}
.btn{display:inline-block;font-family:'Nunito Sans',sans-serif;font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 2.2rem;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all var(--trans);text-decoration:none;}
.btn-primary{background:var(--sky);color:var(--white);border-color:var(--sky);}
.btn-primary:hover{background:var(--sky-dark);border-color:var(--sky-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,143,204,.35);}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6);}
.btn-outline:hover{background:rgba(255,255,255,.15);border-color:var(--white);color:var(--white);}
.badge{display:inline-block;padding:.25rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;}
.badge-sky{background:var(--sky);color:white;}
.badge-surf{background:var(--surf);color:white;}
.badge-gold{background:var(--gold);color:white;}
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease;}
.fade-in.visible{opacity:1;transform:translateY(0);}

/* HEADER */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,46,69,.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(26,143,204,.22);transition:box-shadow var(--trans);}
#site-header.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.22);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:94px;padding:0 5%;max-width:1400px;margin:0 auto;}
.site-logo{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:.03em;}
.site-logo .logo-accent{color:var(--sky-light);}
.site-logo .logo-sub{display:block;font-family:'Nunito Sans',sans-serif;font-size:.6rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:-2px;}
.primary-nav{display:flex;align-items:center;gap:2.2rem;}
.primary-nav a{color:rgba(255,255,255,.78);font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:color var(--trans);}
.primary-nav a:hover{color:var(--sky-light);}
.header-actions{display:flex;align-items:center;gap:1rem;}
.header-cart-link{position:relative;color:white;font-size:1.2rem;text-decoration:none;display:flex;align-items:center;}
.header-cart-link:hover{color:var(--sky-light);}
.cart-count{position:absolute;top:-8px;right:-8px;background:var(--surf);color:white;font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:24px;height:2px;background:white;margin:5px 0;transition:all .3s;}

/* HERO SLIDER */
.hero-slider{position:relative;width:100%;padding-top:70px;overflow:hidden;}
.slides-wrap{display:flex;transition:transform .85s cubic-bezier(.77,0,.18,1);will-change:transform;}
.slide{position:relative;flex:0 0 100%;width:100%;height:calc(100vh - 70px);min-height:480px;max-height:800px;overflow:hidden;}
.slide img{width:100%;height:92%;object-fit:cover;object-position:center;display:block;transition:transform 8s ease;}
.slides-wrap .slide.active img{transform:scale(1.05);}
.slide-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(10,46,69,.78) 0%,rgba(10,46,69,.2) 60%,transparent 100%);padding:3rem 6% 5rem;display:flex;align-items:flex-end;justify-content:space-between;}
.slide-text h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,4rem);font-weight:700;color:#fff;line-height:1.1;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.slide-text p{color:rgba(255,255,255,.82);font-size:1rem;margin-top:.6rem;text-shadow:0 1px 8px rgba(0,0,0,.5);margin-bottom:0;}
.slide-cta{flex-shrink:0;margin-left:2rem;}
.hero-trust-strip{position:absolute;bottom:0;left:0;right:0;background:rgba(10,46,69,.6);backdrop-filter:blur(6px);border-top:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;gap:3rem;padding:.9rem 5%;flex-wrap:wrap;z-index:5;}
.trust-pill{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.9);font-size:.83rem;font-weight:700;}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1.4rem;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background var(--trans);}
.slider-arrow:hover{background:rgba(255,255,255,.32);}
.slider-arrow.prev{left:1.5rem;}.slider-arrow.next{right:1.5rem;}
.slider-dots{position:absolute;bottom:3.5rem;left:20%;transform:translateX(-20%);display:flex;gap:.5rem;z-index:10;}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:background .3s,transform .3s;padding:0;}
.dot.active{background:#fff;transform:scale(1.3);}
.slider-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--sky-light);animation:sliderProgress var(--dur,5s) linear;z-index:10;}
@keyframes sliderProgress{from{width:0;}to{width:100%;}}

/* WAVE */
.wave-divider{display:block;width:100%;overflow:hidden;line-height:0;}
.wave-divider svg{display:block;width:100%;}

/* STATS */
.stats-band{background:linear-gradient(135deg,var(--sky-dark) 0%,var(--sky) 60%,var(--sky-light) 100%);}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);}
.stat-item{padding:2rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.18);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,2.5vw,2.3rem);font-weight:700;color:white;line-height:1;}
.stat-label{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.68);margin-top:.4rem;}

/* SHOP */
.shop-section{background:var(--off-white);padding:5rem 0;}
/* ── PRODUCT GRID: 3-column layout ── */
.woocommerce ul.products,
.woocommerce-page ul.products,
.woocommerce .products,
.woocommerce-page .products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  clear: both !important;
}
/* Kill WooCommerce float & width on each card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  transition: transform var(--trans), box-shadow var(--trans) !important;
  box-shadow: 0 2px 12px rgba(10,46,69,.06) !important;
}
.woocommerce ul.products li.product:hover{transform:translateY(-6px)!important;box-shadow:0 20px 50px rgba(10,46,69,.16)!important;}
.woocommerce ul.products li.product img{width:100%!important;height:290px!important;object-fit:cover!important;transition:transform .5s ease!important;display:block!important;}
.woocommerce ul.products li.product:hover img{transform:scale(1.05)!important;}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:'Playfair Display',serif!important;font-size:1.15rem!important;font-weight:700!important;color:var(--ocean)!important;margin-bottom:.4rem!important;line-height:1.25!important;}
.woocommerce ul.products li.product .price{font-family:'Playfair Display',serif!important;font-size:1.3rem!important;font-weight:700!important;color:var(--sky-dark)!important;}
.woocommerce ul.products li.product .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{background:var(--sky)!important;color:white!important;border:none!important;padding:.6rem 1.2rem!important;border-radius:var(--radius)!important;font-family:'Nunito Sans',sans-serif!important;font-size:.78rem!important;font-weight:700!important;letter-spacing:.08em!important;text-transform:uppercase!important;cursor:pointer!important;transition:background var(--trans)!important;text-decoration:none!important;display:inline-block!important;}
.woocommerce ul.products li.product .button:hover,
.woocommerce a.button:hover{background:var(--sky-dark)!important;color:white!important;}
.woocommerce a.button.added_to_cart{background:var(--surf)!important;}
.product-short-desc{font-size:.84rem;color:var(--mid);line-height:1.65;margin-bottom:1rem;}

/* SINGLE PRODUCT */
.woocommerce div.product{padding-top:6rem;}
.woocommerce div.product div.images{width:48%!important;float:left!important;}
.woocommerce div.product div.summary{width:48%!important;float:right!important;}
.woocommerce div.product .product_title{font-family:'Playfair Display',serif!important;font-size:2.2rem!important;color:var(--ocean)!important;}
.woocommerce div.product p.price{font-family:'Playfair Display',serif!important;font-size:2rem!important;color:var(--sky-dark)!important;font-weight:700!important;}
.woocommerce div.product form.cart .single_add_to_cart_button{background:var(--sky)!important;border-color:var(--sky)!important;padding:1rem 2.5rem!important;font-size:.9rem!important;font-weight:700!important;letter-spacing:.12em!important;text-transform:uppercase!important;border-radius:var(--radius)!important;}
.woocommerce div.product form.cart .single_add_to_cart_button:hover{background:var(--sky-dark)!important;border-color:var(--sky-dark)!important;}

/* CHECKOUT */
.woocommerce table.shop_table th{background:var(--sky-pale)!important;color:var(--ocean)!important;font-family:'Nunito Sans',sans-serif!important;font-size:.78rem!important;font-weight:700!important;letter-spacing:.1em!important;text-transform:uppercase!important;padding:1rem 1.2rem!important;}
.woocommerce table.shop_table td{padding:1rem 1.2rem!important;}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea{border:2px solid var(--border)!important;border-radius:var(--radius)!important;padding:.75rem 1rem!important;font-family:'Nunito Sans',sans-serif!important;}
.woocommerce-checkout .form-row input:focus{border-color:var(--sky)!important;outline:none!important;box-shadow:0 0 0 3px rgba(26,143,204,.15)!important;}
#place_order{background:var(--sky)!important;border-color:var(--sky)!important;color:white!important;padding:1.1rem 2.5rem!important;font-size:1rem!important;font-weight:700!important;width:100%!important;border-radius:var(--radius)!important;letter-spacing:.12em!important;text-transform:uppercase!important;}
#place_order:hover{background:var(--sky-dark)!important;border-color:var(--sky-dark)!important;}
.StripeElement{border:2px solid var(--border)!important;border-radius:var(--radius)!important;padding:.85rem 1rem!important;}
.StripeElement--focus{border-color:var(--sky)!important;box-shadow:0 0 0 3px rgba(26,143,204,.15)!important;}
.woocommerce-message,.woocommerce-info{background:var(--sky-pale)!important;border-top-color:var(--sky)!important;color:var(--ocean)!important;}

/* FEATURES */
.features-section{background:var(--white);padding:5rem 0;}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:2rem;max-width:1100px;}
.feature-card{background:var(--sky-pale);border-radius:var(--radius);padding:2rem;border:1px solid var(--border);transition:transform var(--trans),box-shadow var(--trans);}
.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(10,46,69,.1);}
.feature-icon{width:56px;height:56px;background:var(--sky);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.5rem;}
.feature-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--ocean);margin-bottom:.5rem;font-weight:700;}
.feature-text{font-size:.88rem;color:var(--mid);line-height:1.75;}

/* HOW IT WORKS */
.how-section{background:linear-gradient(135deg,var(--ocean) 0%,var(--sky-deeper) 60%,var(--sky-dark) 100%);color:white;position:relative;overflow:hidden;}
.how-section::before{content:'';position:absolute;top:-80px;right:-80px;width:480px;height:480px;background:radial-gradient(circle,rgba(26,143,204,.18) 0%,transparent 70%);border-radius:50%;}
.how-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:1;}
.how-img-wrap{position:relative;}
.how-img{width:100%;border-radius:var(--radius);object-fit:cover;height:480px;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.how-img-badge{position:absolute;bottom:-20px;right:-20px;background:var(--surf);color:white;padding:1rem;border-radius:50%;width:90px;height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;line-height:1.2;text-align:center;box-shadow:0 8px 24px rgba(0,196,180,.4);}
.how-img-badge small{font-family:'Nunito Sans',sans-serif;font-size:.48rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-top:.2rem;}
.how-text .section-title{color:white;}
.how-text .section-desc{color:rgba(255,255,255,.65);}
.steps{display:flex;flex-direction:column;gap:2rem;}
.step{display:flex;gap:1.5rem;align-items:flex-start;}
.step-num{font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;color:var(--sky-light);line-height:1;min-width:50px;opacity:.8;}
.step-content h3{font-family:'Playfair Display',serif;font-size:1.2rem;color:white;margin-bottom:.4rem;}
.step-content p{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.7;margin:0;}

/* TESTIMONIALS */
.testimonials-section{background:var(--off-white);}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;max-width:1100px;}
.testimonial-card{background:white;border-radius:var(--radius);padding:2rem;border:1px solid var(--border);position:relative;}
.testimonial-card::before{content:'\201C';font-family:'Playfair Display',serif;font-size:5rem;color:var(--sky-pale);position:absolute;top:-10px;left:16px;line-height:1;}
.testimonial-stars{color:var(--gold);font-size:.9rem;margin-bottom:.8rem;}
.testimonial-text{font-size:.92rem;color:var(--mid);line-height:1.75;margin-bottom:1.2rem;font-style:italic;}
.testimonial-author{font-size:.82rem;font-weight:700;color:var(--ocean);}
.testimonial-location{font-size:.75rem;color:var(--mid);}

/* CONTACT */
.contact-section{background:var(--white);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;max-width:1000px;}
.contact-info h3{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--ocean);margin-bottom:1rem;}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.2rem;}
.contact-detail-icon{font-size:1.3rem;margin-top:2px;}
.contact-detail-text{font-size:.9rem;color:var(--mid);line-height:1.6;}
.contact-detail-text strong{display:block;color:var(--ocean);font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;}
.contact-form input,.contact-form textarea{width:100%;padding:.85rem 1rem;border:2px solid var(--border);border-radius:var(--radius);font-family:'Nunito Sans',sans-serif;font-size:.9rem;color:var(--text);margin-bottom:1rem;transition:border-color var(--trans),box-shadow var(--trans);}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--sky);outline:none;box-shadow:0 0 0 3px rgba(26,143,204,.12);}
.contact-form textarea{height:130px;resize:vertical;}
.contact-form label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ocean);margin-bottom:.35rem;}

/* FOOTER */
#site-footer{background:linear-gradient(135deg,var(--ocean) 0%,var(--sky-deeper) 100%);color:rgba(255,255,255,.6);padding:5rem 0 2rem;}
.footer-grid{display:grid;grid-template-columns:2.5fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:3.5rem;}
.footer-brand{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:white;margin-bottom:.8rem;}
.footer-brand .accent{color:var(--sky-light);}
.footer-tagline{font-size:.88rem;line-height:1.75;margin-bottom:1.5rem;}
.footer-col h4{color:white;font-family:'Nunito Sans',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem;}
.footer-col a{display:block;color:rgba(255,255,255,.55);font-size:.88rem;text-decoration:none;margin-bottom:.6rem;transition:color var(--trans);}
.footer-col a:hover{color:var(--sky-light);}
.footer-newsletter-input{display:flex;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.2);}
.footer-newsletter-input input{flex:1;padding:.7rem 1rem;background:rgba(255,255,255,.08);border:none;color:white;font-size:.85rem;font-family:'Nunito Sans',sans-serif;}
.footer-newsletter-input input::placeholder{color:rgba(255,255,255,.4);}
.footer-newsletter-input input:focus{outline:none;background:rgba(255,255,255,.12);}
.footer-newsletter-input button{padding:.7rem 1.1rem;background:var(--sky);border:none;color:white;cursor:pointer;font-weight:700;font-size:.8rem;transition:background var(--trans);}
.footer-newsletter-input button:hover{background:var(--sky-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem;}
.footer-bottom a{color:rgba(255,255,255,.45);text-decoration:none;}
.footer-bottom a:hover{color:var(--sky-light);}

/* RESPONSIVE */
@media(max-width:1024px){
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .how-layout{grid-template-columns:1fr;gap:3rem;}
  .how-img{height:320px;}
  .woocommerce div.product div.images,
  .woocommerce div.product div.summary{width:100%!important;float:none!important;}
}
@media(max-width:768px){
  .primary-nav{display:none;}
  .primary-nav.open{display:flex;flex-direction:column;position:absolute;top:70px;left:0;right:0;background:var(--ocean);padding:1.5rem;gap:1.2rem;z-index:999;}
  .hamburger{display:block;}
  .footer-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .slide-cta{display:none;}
  .slide-caption{padding:2rem 5% 5rem;}
  .slide-text h2{font-size:clamp(1.6rem,6vw,2.8rem);}
  .hero-trust-strip{gap:1.2rem;}
}
@media(max-width:480px){
  .stats-inner{grid-template-columns:1fr 1fr;}
  /* mobile single col handled below */
}



/* ── PRODUCT CARD: hover effect & image ── */
.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 40px rgba(10,46,69,.15) !important;
}
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: 260px !important;
  object-fit: cover !important;
  transition: transform .5s ease !important;
  display: block !important;
  border-radius: 0 !important;
}
.woocommerce ul.products li.product:hover a img {
  transform: scale(1.05) !important;
}

/* ── PRODUCT CARD: text & button layout ── */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--ocean) !important;
  padding: .9rem 1.2rem .3rem !important;
  line-height: 1.25 !important;
  margin: 0 !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
  display: block;
}
.woocommerce ul.products li.product .product-short-desc {
  font-size: .84rem;
  color: var(--mid);
  line-height: 1.6;
  padding: .2rem 1.2rem .6rem;
  margin: 0;
}
.woocommerce ul.products li.product .price {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--sky-dark) !important;
  padding: .4rem 1.2rem !important;
  display: block !important;
  border-top: 1px solid var(--border) !important;
  margin: .3rem 0 0 !important;
}
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button {
  display: block !important;
  width: calc(100% - 2.4rem) !important;
  margin: .7rem 1.2rem 1.2rem !important;
  text-align: center !important;
  background: var(--sky) !important;
  color: white !important;
  border: none !important;
  padding: .7rem 1rem !important;
  border-radius: var(--radius) !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background var(--trans) !important;
  text-decoration: none !important;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--sky-dark) !important;
  color: white !important;
}
.woocommerce a.button.added_to_cart {
  background: var(--surf) !important;
}

/* ── RESPONSIVE GRID ── */
@media (max-width: 900px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce .products,
  .woocommerce-page .products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 540px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce .products,
  .woocommerce-page .products {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   OUR OWN PRODUCTS-GRID — matches HTML preview exactly
   Uses .products-grid / .product-card (not WooCommerce ul.products)
   so WooCommerce CANNOT override it.
═══════════════════════════════════════════════════════════ */
ul.products-grid,
.products-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2rem !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.product-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s, box-shadow .3s;
  box-shadow: 0 2px 12px rgba(13,61,110,.07);
  display: flex;
  flex-direction: column;
  list-style: none;
}
.product-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 20px 50px rgba(13,61,110,.18);
}

.product-card-link { display: block; text-decoration: none; }

.prod-img-wrap {
  height: 240px;
  overflow: hidden;
  background: var(--sky-pale);
  position: relative;
  flex-shrink: 0;
}
.prod-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
  display: block;
}
.product-card:hover .prod-img { transform: scale(1.05); }

.prod-badges {
  position: absolute;
  top: 12px; left: 12px;
  display: flex; gap: .35rem;
}

.prod-body {
  padding: 1rem 1.2rem .8rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.prod-cat {
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--sky);
  margin-bottom: .25rem;
}
.prod-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ocean);
  margin-bottom: .35rem;
  line-height: 1.25;
}
.prod-name a { color: var(--ocean); text-decoration: none; }
.prod-name a:hover { color: var(--sky); }

.prod-short {
  font-size: .83rem;
  color: var(--mid);
  line-height: 1.6;
  margin-bottom: 0;
  flex: 1;
}

.prod-foot {
  border-top: 1px solid var(--border);
  padding: .85rem 0 0;
  margin-top: .9rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
}
.prod-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--sky-dark);
  line-height: 1;
}
.prod-price small {
  font-family: 'Nunito Sans', sans-serif;
  font-size: .62rem;
  font-weight: 600;
  color: var(--mid);
  display: block;
  line-height: 1.3;
}
/* WooCommerce price inside our card */
.prod-price .woocommerce-Price-amount {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--sky-dark);
}

.add-btn {
  background: var(--sky);
  color: #fff;
  border: none;
  padding: .65rem 1.1rem;
  border-radius: 8px;
  font-family: 'Nunito Sans', sans-serif;
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
  text-decoration: none;
  display: inline-block;
  white-space: nowrap;
  flex-shrink: 0;
}
.add-btn:hover,
.add-btn:focus { background: var(--sky-dark); color: #fff; }
.add-btn.added { background: var(--surf); }

/* Responsive */
@media (max-width: 900px) {
  ul.products-grid, .products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 540px) {
  ul.products-grid, .products-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE — Complete fix
   Fixes: gallery thumbnails horizontal, proper 2-col layout,
   related products grid, Add to Cart button styling
═══════════════════════════════════════════════════════════════ */

/* ── Page wrapper: push below fixed header ── */
.woocommerce div.product {
  padding-top: 2rem !important;
  overflow: hidden;
}

/* ── Two-column layout: image left, summary right ── */
.woocommerce div.product div.images {
  width: 46% !important;
  float: left !important;
  margin-right: 4% !important;
  margin-bottom: 2rem !important;
}
.woocommerce div.product div.summary {
  width: 50% !important;
  float: left !important;
  margin: 0 !important;
}

/* ── Clear after product columns ── */
.woocommerce div.product::after,
.woocommerce #content div.product::after {
  content: '' !important;
  display: table !important;
  clear: both !important;
}

/* ── Main product image ── */
.woocommerce div.product div.images .woocommerce-product-gallery {
  position: relative;
}
.woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
  margin: 0 !important;
}
.woocommerce div.product div.images img {
  width: 100% !important;
  height: auto !important;
  border-radius: 12px !important;
  max-height: none !important;
  float: none !important;
}
.woocommerce-product-gallery__image {
  border-radius: 12px;
  overflow: hidden;
}
.woocommerce-product-gallery__image img {
  border-radius: 12px !important;
}

/* ── GALLERY THUMBNAILS: force horizontal row ── */
.woocommerce-product-gallery .flex-control-nav,
.woocommerce-product-gallery .flex-control-thumbs {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: .6rem !important;
  margin: .8rem 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  overflow: visible !important;
}
.woocommerce-product-gallery .flex-control-thumbs li {
  width: calc(25% - .5rem) !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce-product-gallery .flex-control-thumbs li img {
  width: 100% !important;
  height: 70px !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  border: 2px solid transparent !important;
  transition: border-color .2s, opacity .2s !important;
  opacity: .7 !important;
}
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active,
.woocommerce-product-gallery .flex-control-thumbs li img:hover {
  border-color: var(--sky) !important;
  opacity: 1 !important;
}

/* ── Product title & price ── */
.woocommerce div.product .product_title {
  font-family: 'Playfair Display', serif !important;
  font-size: 2rem !important;
  color: var(--ocean) !important;
  line-height: 1.2 !important;
  margin-bottom: .75rem !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.8rem !important;
  color: var(--sky-dark) !important;
  font-weight: 700 !important;
  margin-bottom: 1rem !important;
}
.woocommerce div.product .woocommerce-Price-amount {
  color: var(--sky-dark) !important;
}

/* ── Short description ── */
.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: .95rem !important;
  color: var(--mid) !important;
  line-height: 1.75 !important;
  margin-bottom: 1.5rem !important;
}

/* ── Qty input ── */
.woocommerce div.product form.cart .qty {
  border: 2px solid var(--border) !important;
  border-radius: 8px !important;
  padding: .6rem .8rem !important;
  font-size: 1rem !important;
  width: 65px !important;
  text-align: center !important;
}

/* ── Add to Cart button ── */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce div.product form.cart button[type=submit] {
  background: var(--sky) !important;
  color: white !important;
  border: none !important;
  border-radius: 8px !important;
  padding: .85rem 2rem !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: .88rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background var(--trans), transform var(--trans) !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: var(--sky-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(38,121,189,.35) !important;
}

/* ── Product tabs ── */
.woocommerce div.product .woocommerce-tabs {
  clear: both !important;
  margin-top: 2.5rem !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex !important;
  gap: 0 !important;
  border-bottom: 2px solid var(--border) !important;
  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  list-style: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none !important;
  background: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: var(--mid) !important;
  padding: .75rem 1.5rem !important;
  display: block !important;
  border-bottom: 3px solid transparent !important;
  margin-bottom: -2px !important;
  text-decoration: none !important;
  transition: color var(--trans), border-color var(--trans) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--sky) !important;
  border-bottom-color: var(--sky) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  padding: 0 !important;
  font-size: .92rem !important;
  color: var(--mid) !important;
  line-height: 1.8 !important;
}

/* ── Related products section ── */
.woocommerce .related {
  clear: both !important;
  margin-top: 3rem !important;
}
.woocommerce .related h2,
.woocommerce .up-sells h2 {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.6rem !important;
  color: var(--ocean) !important;
  margin-bottom: 1.5rem !important;
  font-weight: 700 !important;
}

/* Related products grid — 3 columns, proper sizing */
.woocommerce .related ul.products,
.woocommerce .up-sells ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.5rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  width: 100% !important;
  clear: both !important;
}
.woocommerce .related ul.products li.product,
.woocommerce .up-sells ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 10px rgba(13,61,110,.07) !important;
  transition: transform var(--trans), box-shadow var(--trans) !important;
  list-style: none !important;
}
.woocommerce .related ul.products li.product:hover,
.woocommerce .up-sells ul.products li.product:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 14px 36px rgba(13,61,110,.15) !important;
}
.woocommerce .related ul.products li.product a img,
.woocommerce .up-sells ul.products li.product a img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
}
.woocommerce .related ul.products li.product .woocommerce-loop-product__title,
.woocommerce .up-sells ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Playfair Display', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--ocean) !important;
  padding: .75rem 1rem .3rem !important;
  line-height: 1.25 !important;
}
.woocommerce .related ul.products li.product .price,
.woocommerce .up-sells ul.products li.product .price {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.1rem !important;
  color: var(--sky-dark) !important;
  font-weight: 700 !important;
  padding: .2rem 1rem .5rem !important;
  display: block !important;
}
.woocommerce .related ul.products li.product .button,
.woocommerce .up-sells ul.products li.product .button {
  display: block !important;
  width: calc(100% - 2rem) !important;
  margin: .4rem 1rem 1rem !important;
  text-align: center !important;
  background: var(--sky) !important;
  color: white !important;
  padding: .6rem 1rem !important;
  border-radius: 8px !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: .76rem !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border: none !important;
  cursor: pointer !important;
  text-decoration: none !important;
  transition: background var(--trans) !important;
}
.woocommerce .related ul.products li.product .button:hover,
.woocommerce .up-sells ul.products li.product .button:hover {
  background: var(--sky-dark) !important;
  color: white !important;
}

/* ── Meta (category, SKU) ── */
.woocommerce div.product .product_meta {
  font-size: .85rem !important;
  color: var(--mid) !important;
  margin-top: 1rem !important;
}
.woocommerce div.product .product_meta a {
  color: var(--sky) !important;
}

/* ── Responsive: stack on tablet/mobile ── */
@media (max-width: 768px) {
  .woocommerce div.product div.images {
    width: 100% !important;
    float: none !important;
    margin-right: 0 !important;
    margin-bottom: 1.5rem !important;
  }
  .woocommerce div.product div.summary {
    width: 100% !important;
    float: none !important;
  }
  .woocommerce .related ul.products,
  .woocommerce .up-sells ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .woocommerce-product-gallery .flex-control-thumbs li {
    width: calc(33% - .5rem) !important;
  }
}
@media (max-width: 480px) {
  .woocommerce .related ul.products,
  .woocommerce .up-sells ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════
   SINGLE PRODUCT FIXES v2
   - Hide/shrink zoom magnifier icon
   - Fix related products to full width 3-col grid
═══════════════════════════════════════════════════ */

/* ── Zoom magnifier icon: make it small and subtle ── */
.woocommerce-product-gallery__trigger {
  position: absolute !important;
  top: .75rem !important;
  right: .75rem !important;
  width: 36px !important;
  height: 36px !important;
  background: rgba(255,255,255,.85) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 10 !important;
  text-decoration: none !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.15) !important;
  transition: background .2s !important;
  overflow: hidden !important;
}
.woocommerce-product-gallery__trigger:hover {
  background: white !important;
}
/* The actual SVG/img inside the trigger */
.woocommerce-product-gallery__trigger img,
.woocommerce-product-gallery__trigger svg {
  width: 18px !important;
  height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  display: block !important;
}
/* If WooCommerce outputs it as a plain anchor with no image — hide the text */
.woocommerce-product-gallery__trigger::before {
  content: '🔍' !important;
  font-size: 14px !important;
  line-height: 1 !important;
}

/* ── Related products: force full-width 3-col ── */
.woocommerce .related,
.woocommerce .up-sells {
  width: 100% !important;
  float: none !important;
  clear: both !important;
  margin-top: 3rem !important;
  display: block !important;
}

/* Kill any width restriction WooCommerce puts on related */
.woocommerce .related > ul,
.woocommerce .related ul.products,
.woocommerce .up-sells ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.5rem !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  clear: both !important;
}

/* Each related product card */
.woocommerce .related ul.products li.product,
.woocommerce .up-sells ul.products li.product {
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 10px rgba(13,61,110,.07) !important;
  transition: transform .3s, box-shadow .3s !important;
  display: flex !important;
  flex-direction: column !important;
}
.woocommerce .related ul.products li.product:hover,
.woocommerce .up-sells ul.products li.product:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 16px 40px rgba(13,61,110,.15) !important;
}

/* Related card image — full width, fixed height */
.woocommerce .related ul.products li.product a,
.woocommerce .up-sells ul.products li.product a {
  display: block !important;
  text-decoration: none !important;
}
.woocommerce .related ul.products li.product a img,
.woocommerce .up-sells ul.products li.product a img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
  float: none !important;
}

/* Related card title */
.woocommerce .related ul.products li.product .woocommerce-loop-product__title,
.woocommerce .up-sells ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Playfair Display', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--ocean) !important;
  padding: .8rem 1rem .3rem !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}

/* Related card price */
.woocommerce .related ul.products li.product .price,
.woocommerce .up-sells ul.products li.product .price {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.1rem !important;
  color: var(--sky-dark) !important;
  font-weight: 700 !important;
  padding: .2rem 1rem .5rem !important;
  display: block !important;
  margin: 0 !important;
}

/* Related card Add to Cart button */
.woocommerce .related ul.products li.product .button,
.woocommerce .up-sells ul.products li.product .button {
  display: block !important;
  width: calc(100% - 2rem) !important;
  margin: auto 1rem 1rem !important;
  text-align: center !important;
  background: var(--sky) !important;
  color: white !important;
  padding: .65rem 1rem !important;
  border-radius: 8px !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: .76rem !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border: none !important;
  cursor: pointer !important;
  text-decoration: none !important;
  transition: background .2s !important;
  margin-top: auto !important;
}
.woocommerce .related ul.products li.product .button:hover,
.woocommerce .up-sells ul.products li.product .button:hover {
  background: var(--sky-dark) !important;
  color: white !important;
}

/* Responsive related products */
@media (max-width: 768px) {
  .woocommerce .related ul.products,
  .woocommerce .up-sells ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  .woocommerce .related ul.products,
  .woocommerce .up-sells ul.products {
    grid-template-columns: 1fr !important;
  }
}
