/*
Theme Name: HK Florists 香港花店
Theme URI: https://hkflorists.net
Author: HK Florists
Author URI: https://hkflorists.net
Description: Custom bilingual WooCommerce theme for Hong Kong flower delivery. Cantonese-first, GSAP animations, JSON-LD rich, PageSpeed optimized.
Version: 1.2.0
License: Proprietary
Text Domain: hkflorists
*/

:root {
  --crimson: #8B1A2B;
  --crimson-dark: #6B1220;
  --gold: #C9A96E;
  --gold-light: #E0CDA0;
  --jade: #2E8B57;
  --cream: #FAF7F2;
  --charcoal: #2C2420;
  --text: #3D322C;
  --text-light: #6B5E55;
  --white: #FFFFFF;
  --radius: 8px;
  --shadow: 0 2px 16px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.12);
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Noto Sans HK','Noto Sans SC',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--white);color:var(--text);line-height:1.7;overflow-x:hidden}
body.en{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif}
img{max-width:100%;height:auto;display:block}
a{color:var(--crimson);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--crimson-dark)}
:focus-visible{outline:2px solid var(--jade);outline-offset:2px}

/* ── Typography ── */
h1,h2,h3,h4{font-family:'Noto Serif HK','Noto Serif SC','Playfair Display',serif;line-height:1.25;color:var(--charcoal)}
body.en h1,body.en h2,body.en h3,body.en h4{font-family:'Playfair Display','Noto Serif HK',serif}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700}
h2{font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:600}
h3{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:600}
p{margin-bottom:1rem}
.lead{font-size:1.15rem;color:var(--text-light);max-width:600px}
.eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:.8rem;font-weight:600;color:var(--gold);margin-bottom:.5rem}

/* ── Layout ── */
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.container-narrow{max-width:900px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-cream{background:var(--cream)}
.text-center{text-align:center}
.section-header{margin-bottom:3rem;text-align:center}
.section-header p{margin-bottom:.25rem}
.divider{width:60px;height:3px;background:var(--gold);margin:1rem auto}
.divider-left{margin-left:0}

/* ── Buttons ── */
.btn,.hero-cta,.hero-cta-alt,button[type=submit]{display:inline-block;padding:.85rem 2rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition);border:none;text-align:center}
.btn-primary,.hero-cta{background:var(--crimson);color:var(--white)}
.btn-primary:hover,.hero-cta:hover{background:var(--crimson-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139,26,43,.3)}
.btn-outline,.hero-cta-alt{border:2px solid var(--crimson);color:var(--crimson);background:transparent}
.btn-outline:hover,.hero-cta-alt:hover{background:var(--crimson);color:var(--white)}
.btn-sm{padding:.5rem 1.25rem;font-size:.85rem}

/* ── Header ── */
.site-header{position:sticky;top:0;z-index:1000;background:var(--white);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 1px 8px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:.75rem 1.5rem}
.brand{display:flex;align-items:baseline;gap:.6rem}
.brand-zh{font-family:'Noto Serif HK',serif;font-size:1.4rem;font-weight:700;color:var(--crimson)}
.brand-en{font-size:.8rem;color:var(--gold);font-weight:500;letter-spacing:1px;text-transform:uppercase}
.main-nav ul{display:flex;list-style:none;gap:1.75rem}
.main-nav a{color:var(--charcoal);font-weight:500;font-size:.9rem;padding:.5rem 0;position:relative}
.main-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--crimson);transition:width var(--transition)}
.main-nav a:hover::after,.main-nav .current-menu-item a::after{width:100%}
.header-actions{display:flex;align-items:center;gap:1rem}
.cart-icon{position:relative;font-size:1.3rem;color:var(--charcoal)}
.cart-count{position:absolute;top:-6px;right:-10px;background:var(--crimson);color:white;font-size:.65rem;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.lang-switch{display:flex;gap:.25rem;font-size:.8rem}
.lang-switch a{padding:.2rem .5rem;border-radius:4px;color:var(--text-light);font-weight:500}
.lang-switch a.active{background:var(--crimson);color:white}
.mobile-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--charcoal)}

/* ── Announcement Bar ── */
.banner-strip{background:var(--charcoal);color:var(--white);text-align:center;padding:.6rem 1rem;font-size:.85rem}
.banner-strip strong{color:var(--gold-light)}

/* ── Hero ── */
.hero{position:relative;height:85vh;min-height:600px;max-height:900px;overflow:hidden;background:var(--charcoal)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.35) 100%)}
.hero-content{position:absolute;bottom:15%;left:50%;transform:translateX(-50%);text-align:center;color:white;width:90%;max-width:700px;z-index:2}
.hero-content h1{color:white;margin-bottom:.75rem}
.hero-content .lead{color:rgba(255,255,255,.85);margin-bottom:1.5rem;max-width:100%}
.hero-content .hero-cta{margin-right:.75rem}
.hero-dots{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:2}
.hero-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:transparent;cursor:pointer;transition:all .3s}
.hero-dot.active{background:white;border-color:white}
.hero-scroll{position:absolute;bottom:3%;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.75rem;text-transform:uppercase;letter-spacing:2px;z-index:2}

/* ── Trust Strip ── */
.trust-strip{display:flex;justify-content:center;gap:3rem;padding:2rem 1rem;background:var(--white);border-bottom:1px solid rgba(0,0,0,.06)}
.trust-item{display:flex;align-items:center;gap:.75rem}
.trust-icon{font-size:1.5rem}
.trust-text strong{display:block;font-size:.9rem;color:var(--charcoal)}
.trust-text span{font-size:.8rem;color:var(--text-light)}

/* ── Product Grid ── */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.product-card{background:white;border-radius:var(--radius);overflow:hidden;transition:all var(--transition);box-shadow:var(--shadow)}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-card-img{position:relative;overflow:hidden;aspect-ratio:4/5}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .product-card-img img{transform:scale(1.05)}
.product-card-badge{position:absolute;top:.75rem;left:.75rem;background:var(--crimson);color:white;padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}
.product-card-body{padding:1.25rem}
.product-card-body h3{font-size:1rem;margin-bottom:.35rem;color:var(--charcoal)}
.product-card-body .price{font-weight:600;color:var(--crimson);margin-bottom:.75rem}
.product-card-link{display:block;text-align:center;padding:.65rem;background:var(--cream);color:var(--crimson);font-weight:600;font-size:.85rem;border-radius:0 0 var(--radius) var(--radius);transition:all .2s}
.product-card:hover .product-card-link{background:var(--crimson);color:white}

/* ── Occasion Grid ── */
.occasions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.occasion-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1;display:flex;align-items:flex-end}
.occasion-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.occasion-card:hover img{transform:scale(1.08)}
.occasion-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);z-index:1}
.occasion-label{position:relative;z-index:2;padding:1.25rem;color:white;font-weight:600;font-size:1.1rem;width:100%}

/* ── Steps ── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.step{text-align:center;padding:2rem}
.step-number{width:48px;height:48px;border-radius:50%;background:var(--crimson);color:white;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;margin:0 auto 1rem}
.step h3{margin-bottom:.5rem}

/* ── About Block ── */
.about-block{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about-image{border-radius:var(--radius);overflow:hidden}
.about-image img{width:100%;height:500px;object-fit:cover}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}
.about-stat{text-align:center;padding:.75rem;background:white;border-radius:var(--radius)}
.about-stat-number{font-size:1.2rem;font-weight:700;color:var(--crimson)}
.about-stat-label{font-size:.7rem;color:var(--text-light);text-transform:uppercase;letter-spacing:1px;margin-top:.2rem}

/* ── Delivery Areas ── */
.areas-grid{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.area-tag{padding:.5rem 1rem;background:white;border:1px solid rgba(0,0,0,.1);border-radius:20px;font-size:.85rem;color:var(--text);transition:all .2s}
.area-tag:hover{background:var(--crimson);color:white;border-color:var(--crimson)}

/* ── Blog Grid ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{background:white;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-card-img{aspect-ratio:16/10;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:1.25rem}
.blog-card-body .date{font-size:.8rem;color:var(--text-light);margin-bottom:.35rem}
.blog-card-body h3{font-size:1.05rem;margin-bottom:.5rem;color:var(--charcoal)}
.blog-card-body p{font-size:.9rem;color:var(--text-light);margin-bottom:0}
.blog-read-more{color:var(--crimson);font-weight:600;font-size:.85rem;white-space:nowrap}

/* ── FAQ ── */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(0,0,0,.08)}
.faq-question{width:100%;text-align:left;padding:1.25rem 0;background:none;border:none;font-size:1.05rem;font-weight:600;cursor:pointer;color:var(--charcoal);display:flex;justify-content:space-between;align-items:center}
.faq-question::after{content:'+';font-size:1.5rem;color:var(--gold);transition:transform .3s}
.faq-item.open .faq-question::after{content:'−'}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-answer{max-height:300px;padding-bottom:1.25rem}
.faq-answer p{color:var(--text-light)}

/* ── Testimonials ── */
.testimonial-card{padding:3rem;text-align:center;background:var(--cream);border-radius:var(--radius)}
.testimonial-card blockquote{font-family:'Noto Serif HK',serif;font-size:1.2rem;font-style:italic;color:var(--charcoal);margin-bottom:1rem;line-height:1.6}
.testimonial-card cite{color:var(--text-light);font-size:.9rem;font-style:normal}

/* ── CTA Banner ── */
.cta-banner{background:linear-gradient(135deg,var(--crimson),var(--crimson-dark));color:white;text-align:center;padding:4rem 1.5rem}
.cta-banner h2{color:white;margin-bottom:.75rem}
.cta-banner p{color:rgba(255,255,255,.85);margin-bottom:1.5rem}
.cta-banner .hero-cta{background:var(--gold);color:var(--charcoal)}
.cta-banner .hero-cta:hover{background:var(--gold-light);box-shadow:0 4px 12px rgba(201,169,110,.4)}

/* ── Footer ── */
.site-footer{background:var(--charcoal);color:rgba(255,255,255,.65);padding:4rem 1.5rem 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto 3rem}
.footer-brand .brand-zh{color:white;font-size:1.5rem}
.footer-brand p{margin-top:.75rem;font-size:.9rem}
.footer-col h4{color:white;margin-bottom:1rem;font-size:1rem;font-weight:600}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.5rem}
.footer-col a{color:rgba(255,255,255,.55);font-size:.9rem;transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.footer-network{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:1.5rem 0;border-top:1px solid rgba(255,255,255,.08);max-width:1280px;margin:0 auto}
.footer-network a{color:rgba(255,255,255,.35);font-size:.8rem;transition:color .2s}
.footer-network a:hover{color:var(--gold)}
.footer-bottom{text-align:center;font-size:.85rem;color:rgba(255,255,255,.4);padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);max-width:1280px;margin:0 auto}

/* ── Animations (no JS needed, GSAP enhances) ── */
@media (prefers-reduced-motion: no-preference) {
  .reveal{opacity:0;transform:translateY(30px)}
  .reveal.visible{opacity:1;transform:translateY(0);transition:opacity .8s ease,transform .8s ease}
  .reveal-delay-1{transition-delay:.15s}
  .reveal-delay-2{transition-delay:.3s}
  .anim-fade-up{opacity:0;transform:translateY(20px);animation:fadeUp .8s ease forwards}
  .anim-delay-1{animation-delay:.2s}
  .anim-delay-2{animation-delay:.4s}
  .anim-delay-3{animation-delay:.6s}
  @keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .products-grid,.occasions-grid{grid-template-columns:repeat(3,1fr)}
  .about-block{grid-template-columns:1fr}
  .about-stats{grid-template-columns:repeat(4,1fr)}
}
@media (max-width: 768px) {
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .occasions-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .hero{height:70vh;min-height:450px}
  .hero-content h1{font-size:1.6rem}
  .trust-strip{flex-direction:column;align-items:center;gap:1.25rem}
  .about-stats{grid-template-columns:repeat(2,1fr)}
  .mobile-toggle{display:block}
  .main-nav{display:none;position:absolute;top:100%;left:0;width:100%;background:white;border-top:1px solid rgba(0,0,0,.08);padding:1rem}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:.5rem}
  .section{padding:3rem 0}
}
@media (max-width: 480px) {
  .products-grid{grid-template-columns:1fr 1fr}
  .occasions-grid{grid-template-columns:1fr 1fr}
  .section-header .eyebrow{font-size:.7rem}
}

/* ── WooCommerce ────────────────────────────────── */

/* Hide sidebar, make full-width */
.woocommerce .content-area{width:100%!important}
.woocommerce #sidebar,.woocommerce #secondary,.woocommerce .widget-area{display:none!important}
.woocommerce-page .site-main,.woocommerce .site-main{max-width:1280px;margin:0 auto;padding:2rem 1.5rem}

/* Product grid — override default list */
.woocommerce ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;list-style:none;padding:0;margin:0}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none}
.woocommerce ul.products li.product{float:none;width:100%;margin:0;padding:0;background:white;border-radius:var(--radius);overflow:hidden;transition:all var(--transition);box-shadow:var(--shadow);position:relative;text-align:left}
.woocommerce ul.products li.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.woocommerce ul.products li.product img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;margin-bottom:0;border-radius:0}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-size:1rem;font-weight:600;color:var(--charcoal);padding:.75rem 1rem .25rem;margin:0}
.woocommerce ul.products li.product .price{color:var(--crimson);font-weight:600;font-size:.95rem;padding:0 1rem .5rem;margin-bottom:0;display:block}
.woocommerce ul.products li.product .price del{color:var(--text-light);font-weight:400;font-size:.85rem}
.woocommerce ul.products li.product .price ins{text-decoration:none}
.woocommerce ul.products li.product .button,.woocommerce ul.products li.product .add_to_cart_button{display:block;text-align:center;padding:.65rem;background:var(--cream);color:var(--crimson);font-weight:600;font-size:.85rem;border-radius:0 0 var(--radius) var(--radius);border:none;margin:0;transition:all .2s;text-decoration:none}
.woocommerce ul.products li.product .button:hover,.woocommerce ul.products li.product .add_to_cart_button:hover{background:var(--crimson);color:white}
.woocommerce ul.products li.product .onsale{position:absolute;top:.75rem;left:.75rem;background:var(--crimson);color:white;padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;z-index:2;min-height:auto;min-width:auto;line-height:1.6}

/* Result count + ordering */
.woocommerce .woocommerce-result-count{font-size:.85rem;color:var(--text-light);margin-bottom:1rem;float:left}
.woocommerce .woocommerce-ordering{margin-bottom:1.5rem;float:right}
.woocommerce .woocommerce-ordering select{padding:.5rem 2rem .5rem .75rem;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius);font-size:.9rem;background:white;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' fill='none'/%3E%3C/svg%3E\");background-repeat:no-repeat;background-position:right .75rem center}
.woocommerce .woocommerce-ordering::after{display:none}

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb{font-size:.85rem;color:var(--text-light);margin-bottom:1.5rem}
.woocommerce .woocommerce-breadcrumb a{color:var(--crimson)}
.woocommerce .woocommerce-breadcrumb a:hover{text-decoration:underline}

/* Pagination */
.woocommerce nav.woocommerce-pagination{text-align:center;margin-top:2.5rem}
.woocommerce nav.woocommerce-pagination ul{display:inline-flex;gap:.25rem;list-style:none;border:none}
.woocommerce nav.woocommerce-pagination ul li{border:none;float:none}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{padding:.5rem .85rem;border-radius:var(--radius);color:var(--text);text-decoration:none;font-size:.9rem;min-width:auto}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--crimson);color:white}
.woocommerce nav.woocommerce-pagination ul li a:hover{background:var(--cream)}

/* Shop page title */
.woocommerce .woocommerce-products-header__title,.woocommerce-page h1.page-title{font-family:'Noto Serif HK',serif;font-size:2rem;margin-bottom:1rem}

/* Category description */
.woocommerce .term-description{margin-bottom:2rem;color:var(--text-light)}

/* Clear floats */
.woocommerce .woocommerce-notices-wrapper,.woocommerce .storefront-sorting{clear:both}

/* ── Single Product ── */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.woocommerce div.product .woocommerce-product-gallery{position:sticky;top:6rem}
.woocommerce div.product .woocommerce-product-gallery img{width:100%;border-radius:var(--radius)}
.woocommerce div.product .product_title{font-size:2rem;margin-bottom:.5rem}
.woocommerce div.product .price{font-size:1.5rem;color:var(--crimson);font-weight:700;margin-bottom:1rem}
.woocommerce div.product .price del{color:var(--text-light);font-size:1.1rem;font-weight:400}
.woocommerce div.product .price ins{text-decoration:none}
.woocommerce div.product .woocommerce-product-details__short-description{margin-bottom:1.5rem;color:var(--text-light)}
.woocommerce div.product form.cart{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem}
.woocommerce div.product form.cart .quantity input{padding:.65rem;width:70px;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius);font-size:.95rem;text-align:center}
.woocommerce div.product form.cart .button{background:var(--crimson);color:white;padding:.75rem 2rem;border:none;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}
.woocommerce div.product form.cart .button:hover{background:var(--crimson-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139,26,43,.3)}
.woocommerce div.product .product_meta{font-size:.85rem;color:var(--text-light);padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}
.woocommerce div.product .product_meta a{color:var(--crimson)}
.woocommerce div.product .woocommerce-tabs{margin-top:3rem}
.woocommerce div.product .woocommerce-tabs ul.tabs{display:flex;list-style:none;border-bottom:2px solid rgba(0,0,0,.06);padding:0;margin:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li{margin:0;border:none;background:none;padding:0;border-radius:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{display:block;padding:.75rem 1.5rem;color:var(--text-light);font-weight:500;text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--crimson);border-bottom-color:var(--crimson)}
.woocommerce div.product .woocommerce-tabs .panel{padding:1.5rem 0}
.woocommerce div.product .related h2{font-size:1.5rem;margin:3rem 0 1.5rem}

/* Cart page */
.woocommerce-cart .shop_table{border-collapse:collapse}
.woocommerce-cart .shop_table th{background:var(--cream);padding:.75rem;text-align:left;font-weight:600;font-size:.9rem}
.woocommerce-cart .shop_table td{padding:.75rem;border-bottom:1px solid rgba(0,0,0,.06)}
.woocommerce-cart .button{background:var(--crimson);color:white;padding:.65rem 1.5rem;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:all .2s}
.woocommerce-cart .button:hover{background:var(--crimson-dark)}

/* Checkout */
.woocommerce-checkout .woocommerce-billing-fields h3,.woocommerce-checkout #order_review_heading{font-size:1.3rem;margin:1.5rem 0 1rem}
.woocommerce-checkout .input-text{padding:.65rem;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius);font-size:.9rem;width:100%}
.woocommerce-checkout #payment{background:var(--cream);padding:1.5rem;border-radius:var(--radius)}
.woocommerce-checkout #place_order{background:var(--crimson);color:white;padding:.75rem 2rem;border:none;border-radius:var(--radius);font-weight:600;font-size:1rem;cursor:pointer;float:right}
.woocommerce-checkout #place_order:hover{background:var(--crimson-dark)}

/* Notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error{padding:1rem 1.5rem;border-radius:var(--radius);margin-bottom:1.5rem;border-left:4px solid}
.woocommerce-message{background:#edf7ed;border-color:var(--jade);color:#1e4620}
.woocommerce-info{background:#e8f0fe;border-color:#4285f4;color:#1a3a6b}
.woocommerce-error{background:#fce8e6;border-color:var(--crimson);color:#5c0d0d}
.woocommerce-message .button{float:right;background:var(--jade);color:white;padding:.4rem 1rem;border-radius:var(--radius);text-decoration:none;font-size:.85rem}

/* Sidebar widgets */
.woocommerce .widget_product_categories ul,.woocommerce .widget_price_filter{margin-bottom:1.5rem}

/* ── WooCommerce Responsive ── */
@media (max-width: 1024px) {
  .woocommerce ul.products{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 768px) {
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)}
  .woocommerce div.product{grid-template-columns:1fr;gap:2rem}
  .woocommerce div.product .woocommerce-product-gallery{position:static}
  .woocommerce .woocommerce-result-count,.woocommerce .woocommerce-ordering{float:none;text-align:center}
}
@media (max-width: 480px) {
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:.75rem}
}
