/*
Theme Name: MiLlaveros
Theme URI: https://millaveros.store
Author: MiLlaveros
Description: Tema colorido y divertido para tienda de llaveros con WooCommerce y DSers.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
WooCommerce: 8.0+
Text Domain: millaveros
*/

@import url('https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap');

/* ============================================================
   DESIGN TOKENS — KeyChain Pop Style
   ============================================================ */
:root {
  --primary:        #FF3E6C;
  --primary-dark:   #E0234F;
  --primary-light:  #FF7096;
  --secondary:      #FFD600;
  --secondary-light:#FFE566;
  --accent:         #00D1B2;
  --accent2:        #7C3AED;
  --bg:             #FFF9F0;
  --bg-alt:         #F0F0F0;
  --surface:        #FFFFFF;
  --text:           #1A1A2E;
  --text-muted:     #777777;
  --text-light:     #9CA3AF;
  --border:         #1A1A2E;
  --shadow-pop:     4px 4px 0px #1A1A2E;
  --shadow-pop-lg:  6px 6px 0px #1A1A2E;
  --shadow-hover:   2px 2px 0px #1A1A2E;
  --radius-sm:      8px;
  --radius-md:      16px;
  --radius-lg:      24px;
  --radius-xl:      40px;
  --radius-full:    999px;
  --font-display:   'Fredoka One', cursive;
  --font-body:      'Nunito', sans-serif;
  --transition:     all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent2)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.2;color:var(--text)}
ul{list-style:none}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.site-wrapper{display:flex;flex-direction:column;min-height:100vh}
.site-main{flex:1}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{background:var(--text);color:#fff;font-size:13px;padding:8px 0;border-bottom:2px solid var(--secondary)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px}
.topbar a{color:rgba(255,255,255,.85);font-weight:600}
.topbar a:hover{color:var(--secondary)}
.topbar-left{display:flex;gap:20px;align-items:center}
.topbar-right{display:flex;gap:16px;align-items:center}
.topbar-icon{display:flex;align-items:center;gap:6px}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{background:var(--surface);border-bottom:3px solid var(--text);position:sticky;top:0;z-index:1000;box-shadow:0 4px 0 var(--secondary)}
.header-inner{display:flex;align-items:center;gap:24px;padding:16px 24px;max-width:1280px;margin:0 auto}
.site-branding{flex-shrink:0}
.site-branding .site-logo img{height:60px;width:auto}
.site-title{font-family:var(--font-display);font-size:28px;color:var(--text);letter-spacing:-.5px;display:flex;align-items:center;gap:8px}
.site-title .logo-icon{width:40px;height:40px;background:var(--primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;border:2px solid var(--text);box-shadow:var(--shadow-pop)}
.site-title span{color:var(--primary)}
.site-tagline{font-size:12px;color:var(--text-muted);margin-top:-2px}

.header-search{flex:1;max-width:480px}
.search-form{display:flex;align-items:center}
.search-form input{flex:1;padding:10px 16px;border:2px solid var(--text);border-right:none;border-radius:var(--radius-full) 0 0 var(--radius-full);font-family:var(--font-body);font-size:14px;background:var(--bg);outline:none}
.search-form input:focus{box-shadow:3px 3px 0 var(--primary)}
.search-form button{padding:10px 20px;background:var(--primary);border:2px solid var(--text);border-radius:0 var(--radius-full) var(--radius-full) 0;cursor:pointer;color:#fff;font-size:16px;transition:var(--transition)}
.search-form button:hover{background:var(--text)}

.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.header-action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:700;font-size:14px;border:2px solid var(--text);cursor:pointer;transition:var(--transition);text-decoration:none;box-shadow:var(--shadow-pop);color:var(--text)}
.header-action-btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-pop-lg);color:var(--text)}
.header-action-btn:active{transform:translate(2px,2px);box-shadow:var(--shadow-hover)}
.header-action-btn .icon{font-size:18px;line-height:1}
.header-action-btn.account-btn{background:var(--secondary)}
.header-action-btn.cart-cta{background:var(--primary);color:#fff}
.header-action-btn.cart-cta:hover{color:#fff}
.cart-count{background:var(--text);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.mobile-menu-toggle{display:none;background:none;border:none;color:var(--text);font-size:26px;cursor:pointer;padding:8px;margin-left:auto}

/* ============================================================
   NAVIGATION
   ============================================================ */
.main-nav{background:var(--text);border-bottom:3px solid var(--secondary)}
.main-nav .container{display:flex;align-items:center}
.main-nav ul{display:flex;align-items:center;flex-wrap:wrap}
.main-nav ul li a{display:block;padding:12px 20px;color:#fff;font-weight:700;font-size:14px;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px;transition:background .15s}
.main-nav ul li a:hover,.main-nav ul li.current-menu-item>a{background:var(--primary);color:#fff}
.main-nav ul li{position:relative}
.main-nav ul li ul{display:none;position:absolute;top:100%;left:0;background:var(--surface);min-width:220px;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-pop-lg);flex-direction:column;z-index:999;border:2px solid var(--text);border-top:3px solid var(--primary)}
.main-nav ul li:hover>ul{display:flex}
.main-nav ul li ul li a{color:var(--text);padding:12px 20px;font-weight:700;font-size:14px;text-transform:none}
.main-nav ul li ul li a:hover{color:#fff;background:var(--primary)}

/* BENEFITS STRIP */
.benefits-strip{background:var(--text);border-top:2px solid var(--secondary);border-bottom:2px solid var(--secondary);padding:12px 20px}
.benefits-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:center;gap:40px;flex-wrap:wrap}
.benefit-item{display:flex;align-items:center;gap:8px;color:#fff;font-weight:700;font-size:13px}
.benefit-icon{font-size:20px}

/* ============================================================
   HERO BANNER
   ============================================================ */
.hero-banner{background:var(--secondary);border-bottom:3px solid var(--text);padding:60px 0;position:relative;overflow:hidden}
.hero-banner .hero-title{color:var(--text)}
.hero-banner .hero-desc{color:var(--text);opacity:.75}
.hero-banner .hero-trust-item{color:var(--text)}
.hero-banner::before{content:'';position:absolute;top:-50px;right:-50px;width:300px;height:300px;background:var(--primary);border-radius:50%;opacity:.12}
.hero-banner::after{content:'';position:absolute;bottom:-80px;left:10%;width:200px;height:200px;background:var(--accent);border-radius:50%;opacity:.12}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1280px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;font-weight:800;font-size:13px;padding:6px 16px;border-radius:var(--radius-full);margin-bottom:20px;border:2px solid var(--text);box-shadow:var(--shadow-pop)}
.hero-title{font-size:clamp(38px,5vw,64px);font-weight:400;line-height:1.1;margin-bottom:20px;color:var(--text)}
.hero-title .highlight{color:var(--primary);-webkit-text-stroke:1px var(--text)}
.hero-desc{font-size:18px;font-weight:600;color:var(--text);opacity:.8;margin-bottom:32px;line-height:1.6}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-image{position:relative;display:flex;justify-content:center;align-items:center}
.hero-image img{border-radius:var(--radius-lg);border:3px solid var(--text);box-shadow:var(--shadow-pop-lg);width:100%;max-height:400px;object-fit:cover}
.hero-image-placeholder{background:linear-gradient(135deg,#FFE5EC,#FFF3CD);border-radius:var(--radius-lg);aspect-ratio:1/1;width:100%;display:flex;align-items:center;justify-content:center;font-size:120px;border:3px solid var(--text);box-shadow:var(--shadow-pop-lg)}
.hero-stats{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-stat{background:var(--surface);border-radius:var(--radius-md);padding:14px 20px;text-align:center;flex:1;border:2px solid var(--text);box-shadow:var(--shadow-pop)}
.hero-stat .number{font-size:26px;font-family:var(--font-display);color:var(--primary)}
.hero-stat .label{font-size:11px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:800;font-size:15px;border:2px solid var(--text);cursor:pointer;transition:var(--transition);text-decoration:none;box-shadow:var(--shadow-pop)}
.btn:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-pop-lg)}
.btn:active{transform:translate(2px,2px);box-shadow:var(--shadow-hover)}
.btn-primary{background:var(--primary);color:#fff}
.btn-secondary{background:var(--secondary);color:var(--text)}
.btn-success{background:var(--accent);color:var(--text)}
.btn-white{background:#fff;color:var(--text)}
.btn-dark{background:var(--text);color:#fff}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}
.btn-outline-white:hover{background:rgba(255,255,255,.15);color:#fff}
.btn-sm{padding:8px 18px;font-size:13px}
.pulse-btn{animation:pulse-ring 2s ease-in-out infinite}
@keyframes pulse-ring{0%{box-shadow:var(--shadow-pop),0 0 0 0 rgba(255,62,108,.4)}70%{box-shadow:var(--shadow-pop),0 0 0 12px rgba(255,62,108,0)}100%{box-shadow:var(--shadow-pop),0 0 0 0 rgba(255,62,108,0)}}

/* ============================================================
   SECTION SHARED
   ============================================================ */
.section-header{text-align:center;margin-bottom:48px}
.section-tag{display:inline-block;background:var(--secondary);color:var(--text);font-weight:800;font-size:12px;padding:5px 16px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;border:2px solid var(--text);box-shadow:2px 2px 0 var(--text)}
.section-title{font-size:clamp(26px,4vw,40px);font-weight:400}
.section-sub{font-size:16px;color:var(--text-muted);margin-top:10px;font-weight:600}
.products-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}

/* ============================================================
   CATEGORIES STRIP
   ============================================================ */
.categories-strip{padding:60px 0}
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px}
.category-card{background:var(--surface);border-radius:var(--radius-md);padding:28px 16px;text-align:center;border:2px solid var(--text);box-shadow:var(--shadow-pop);transition:var(--transition);cursor:pointer;display:block;color:var(--text);text-decoration:none}
.category-card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-pop-lg);color:var(--text)}
.category-card:nth-child(1){background:#FFE5EC}
.category-card:nth-child(2){background:#E5F9F6}
.category-card:nth-child(3){background:#FFF3CD}
.category-card:nth-child(4){background:#EDE9FE}
.category-card:nth-child(5){background:#E0F2FE}
.category-card:nth-child(6){background:#FCE7F3}
.category-card:nth-child(7){background:#F0FDF4}
.category-card:nth-child(8){background:#FFF7ED}
.cat-icon{width:64px;height:64px;background:rgba(255,255,255,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 14px;border:2px solid var(--text)}
.cat-name{font-weight:700;font-size:14px;color:var(--text);font-family:var(--font-display)}
.cat-count{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:600}

/* ============================================================
   PRODUCTS SECTION
   ============================================================ */
.products-section{padding:60px 0;background:var(--bg-alt)}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.product-card,ul.products li.product{background:var(--surface) !important;border:2px solid var(--text) !important;border-radius:var(--radius-md) !important;overflow:hidden;transition:var(--transition);position:relative;box-shadow:var(--shadow-pop) !important}
.product-card:hover,ul.products li.product:hover{transform:translate(-4px,-4px) !important;box-shadow:var(--shadow-pop-lg) !important}
.product-badge{position:absolute;top:12px;left:12px;z-index:2;display:flex;flex-direction:column;gap:6px}
.badge{display:inline-block;font-size:11px;font-weight:800;padding:4px 10px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;border:2px solid var(--text);box-shadow:2px 2px 0 var(--text)}
.badge-sale{background:var(--accent);color:var(--text)}
.badge-new{background:var(--primary);color:#fff}
.badge-hot{background:var(--secondary);color:var(--text)}
.badge-free-ship,.badge-free{background:var(--accent2);color:#fff}
.product-image{position:relative;overflow:hidden;aspect-ratio:1/1;border-bottom:2px solid var(--text)}
.product-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.product-card:hover .product-image img{transform:scale(1.06)}
.product-actions-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(26,26,46,.6));display:flex;justify-content:center;gap:8px;padding:20px 12px 12px;opacity:0;transform:translateY(10px);transition:var(--transition)}
.product-card:hover .product-actions-overlay{opacity:1;transform:translateY(0)}
.action-icon-btn{width:40px;height:40px;background:#fff;border:2px solid var(--text);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-hover)}
.action-icon-btn:hover{background:var(--primary);color:#fff;transform:scale(1.1)}
.product-info{padding:14px}
.product-rating{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.stars{color:var(--secondary);font-size:13px}
.rating-count{font-size:12px;color:var(--text-muted)}
.product-name{font-weight:700;font-size:15px;color:var(--text);margin-bottom:8px;font-family:var(--font-display);line-height:1.3}
.product-name a{color:inherit}
.product-price-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.price-current,.woocommerce-Price-amount{font-size:20px;font-weight:400;color:var(--primary);font-family:var(--font-display)}
.price-original{font-size:14px;color:var(--text-light);text-decoration:line-through}
.price-discount{font-size:11px;font-weight:800;color:var(--text);background:var(--accent);padding:2px 8px;border-radius:var(--radius-full);border:1px solid var(--text)}
.product-shipping{font-size:12px;color:var(--accent2);font-weight:700;display:flex;align-items:center;gap:4px;margin-bottom:12px}
.add-to-cart-btn,.button.add_to_cart_button,.single_add_to_cart_button{width:100% !important;background:var(--primary) !important;color:#fff !important;border:2px solid var(--text) !important;border-radius:var(--radius-full) !important;padding:10px !important;font-family:var(--font-body) !important;font-weight:800 !important;font-size:14px !important;cursor:pointer !important;transition:var(--transition) !important;display:flex !important;align-items:center !important;justify-content:center !important;gap:8px !important;text-transform:none !important;box-shadow:var(--shadow-pop) !important}
.add-to-cart-btn:hover,.button.add_to_cart_button:hover{background:var(--text) !important;transform:translate(-2px,-2px) !important;box-shadow:var(--shadow-pop-lg) !important}

/* ============================================================
   PROMO BANNER
   ============================================================ */
.promo-banner{background:var(--primary);border-top:3px solid var(--text);border-bottom:3px solid var(--text);padding:60px 0;position:relative;overflow:hidden}
.promo-banner::after{content:'🔑';position:absolute;right:5%;top:50%;transform:translateY(-50%);font-size:160px;opacity:.1}
.promo-inner{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;max-width:1280px;margin:0 auto;padding:0 24px}
.promo-title{font-size:clamp(22px,3vw,36px);color:#fff;margin-bottom:10px;font-family:var(--font-body);font-weight:800;line-height:1.3}
.promo-title span{color:var(--secondary)}
.promo-sub{font-size:15px;color:rgba(255,255,255,.9);font-weight:600;font-family:var(--font-body)}
.promo-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}

/* ============================================================
   ALIEXPRESS / DSERS SECTION
   ============================================================ */
.aliexpress-section{padding:60px 0}
.aliexpress-card{background:var(--primary);border-radius:var(--radius-lg);padding:40px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:32px;position:relative;overflow:hidden;border:3px solid var(--text);box-shadow:var(--shadow-pop-lg)}
.aliexpress-card::before{content:'';position:absolute;top:-40%;left:-10%;width:300px;height:300px;background:rgba(255,255,255,.08);border-radius:50%}
.ali-logo{font-size:36px;font-weight:400;color:#fff;font-family:var(--font-display);margin-bottom:8px}
.ali-title{font-size:26px;color:#fff;margin-bottom:8px}
.ali-sub{color:rgba(255,255,255,.85);font-size:15px;margin-bottom:20px;font-weight:600}
.ali-features{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.ali-feature{display:flex;align-items:center;gap:8px;color:#fff;font-size:13px;font-weight:700;background:rgba(255,255,255,.15);padding:6px 14px;border-radius:var(--radius-full);border:2px solid rgba(255,255,255,.3)}

/* ============================================================
   TRUST BADGES
   ============================================================ */
.trust-section{padding:20px 0;background:var(--text);border-top:3px solid var(--secondary);border-bottom:3px solid var(--secondary)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}
.trust-item{display:flex;align-items:center;gap:14px}
.trust-icon{font-size:32px;flex-shrink:0}
.trust-title{font-weight:700;font-size:14px;font-family:var(--font-display);color:#fff}
.trust-desc{font-size:12px;color:rgba(255,255,255,.6)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{padding:80px 0;background:var(--bg-alt)}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.testimonial-card{background:var(--surface);border-radius:var(--radius-md);padding:28px;border:2px solid var(--text);position:relative;box-shadow:var(--shadow-pop);transition:var(--transition)}
.testimonial-card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-pop-lg)}
.testimonial-card::before{content:'"';position:absolute;top:-10px;left:24px;font-size:80px;color:var(--primary);font-family:var(--font-display);line-height:1;opacity:.3}
.t-text{font-size:15px;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic;font-weight:600}
.t-author{display:flex;align-items:center;gap:12px}
.t-avatar{width:44px;height:44px;border-radius:50%;background:var(--secondary);border:2px solid var(--text);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--shadow-hover)}
.t-name{font-weight:700;font-size:14px;font-family:var(--font-display)}
.t-pet{font-size:12px;color:var(--text-muted);font-weight:600}
.t-stars{color:var(--secondary);font-size:14px;margin-left:auto}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter{padding:80px 0}
.newsletter-box{background:var(--text);border-radius:var(--radius-lg);padding:60px;text-align:center;position:relative;overflow:hidden;border:3px solid var(--secondary);box-shadow:var(--shadow-pop-lg)}
.newsletter-box::before{content:'';position:absolute;top:-60px;left:-60px;width:300px;height:300px;background:rgba(255,214,0,.06);border-radius:50%}
.newsletter-box::after{content:'🔑✨🗝️';position:absolute;bottom:-10px;right:20px;font-size:60px;opacity:.15}
.newsletter-title{font-size:clamp(22px,3.5vw,34px);color:#fff;margin-bottom:12px;position:relative;font-family:var(--font-body);font-weight:800}
.newsletter-sub{color:rgba(255,255,255,.9);font-size:15px;margin-bottom:32px;position:relative;font-weight:600;font-family:var(--font-body)}
.newsletter-form{display:flex;gap:0;max-width:480px;margin:0 auto;position:relative}
.newsletter-form input{flex:1;padding:14px 20px;border:2px solid rgba(255,255,255,.3);border-right:none;border-radius:var(--radius-full) 0 0 var(--radius-full);font-family:var(--font-body);font-size:15px;outline:none;background:rgba(255,255,255,.1);color:#fff}
.newsletter-form input::placeholder{color:rgba(255,255,255,.5)}
.newsletter-form button{padding:14px 28px;background:var(--secondary);color:var(--text);border:2px solid rgba(255,255,255,.3);border-radius:0 var(--radius-full) var(--radius-full) 0;font-family:var(--font-body);font-weight:800;font-size:15px;cursor:pointer;transition:var(--transition)}
.newsletter-form button:hover{background:var(--primary);color:#fff;transform:translate(-2px,-2px)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--text);color:rgba(255,255,255,.75);padding:60px 0 0;border-top:3px solid var(--secondary)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-brand .site-title{font-size:24px;margin-bottom:14px;color:#fff}
.footer-brand .logo-icon{width:36px;height:36px;font-size:18px}
.footer-desc{font-size:14px;line-height:1.7;margin-bottom:20px;font-weight:600}
.footer-social{display:flex;gap:10px}
.social-btn{width:38px;height:38px;background:var(--primary);border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--transition);color:#fff;box-shadow:2px 2px 0 rgba(255,255,255,.2)}
.social-btn:hover{background:var(--secondary);color:var(--text);transform:translate(-2px,-2px)}
.footer-col h4{color:var(--secondary);font-weight:400;font-size:18px;margin-bottom:20px;font-family:var(--font-display)}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:rgba(255,255,255,.65);font-size:14px;font-weight:600;transition:color .15s}
.footer-col ul li a:hover{color:var(--secondary)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:14px;font-weight:600}
.footer-contact-icon{font-size:18px;flex-shrink:0;margin-top:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px}
.payment-icons{display:flex;gap:8px;flex-wrap:wrap}
.payment-icon{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:700}

/* ============================================================
   WOOCOMMERCE OVERRIDES
   ============================================================ */
.woocommerce .woocommerce-breadcrumb{font-size:13px;color:var(--text-muted);padding:16px 0;font-weight:600}
.woocommerce .woocommerce-breadcrumb a{color:var(--primary)}
.woocommerce-page .site-main{padding:40px 0}
.woocommerce ul.products{display:grid !important;grid-template-columns:repeat(auto-fill,minmax(240px,1fr)) !important;gap:24px !important}
.woocommerce ul.products li.product{padding:0 !important;float:none !important;width:auto !important;margin:0 !important}
.woocommerce ul.products li.product a img{width:100% !important;height:220px !important;object-fit:cover !important;border-bottom:2px solid var(--text) !important}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--font-display) !important;font-size:17px !important;padding:12px 14px 4px !important;color:var(--text) !important}
.woocommerce ul.products li.product .price{padding:0 14px !important;font-size:18px !important;font-weight:400 !important;color:var(--primary) !important;font-family:var(--font-display) !important}
.woocommerce span.onsale{background:var(--accent) !important;color:var(--text) !important;font-family:var(--font-display) !important;font-size:13px !important;border:2px solid var(--text) !important;border-radius:var(--radius-full) !important;padding:4px 12px !important;box-shadow:2px 2px 0 var(--text) !important;top:12px !important;left:12px !important;min-height:auto !important;line-height:1.5 !important}
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.woocommerce div.product .woocommerce-product-gallery{border:2px solid var(--text);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-pop-lg)}
.woocommerce div.product div.summary .product_title{font-family:var(--font-display) !important;font-size:32px !important;margin-bottom:12px}
.woocommerce div.product div.summary .price{font-family:var(--font-display) !important;font-size:28px !important;color:var(--primary) !important;margin-bottom:16px}
.woocommerce div.product .summary .cart .single_add_to_cart_button{background:var(--primary) !important;color:#fff !important;border:2px solid var(--text) !important;border-radius:var(--radius-full) !important;padding:14px 32px !important;font-family:var(--font-body) !important;font-weight:800 !important;font-size:16px !important;box-shadow:var(--shadow-pop) !important;cursor:pointer !important;transition:var(--transition) !important}
.woocommerce div.product .summary .cart .single_add_to_cart_button:hover{background:var(--text) !important;transform:translate(-3px,-3px) !important;box-shadow:var(--shadow-pop-lg) !important}
.woocommerce table.shop_table{border:2px solid var(--text) !important;border-radius:var(--radius-md) !important;overflow:hidden !important;box-shadow:var(--shadow-pop) !important}
.woocommerce table.shop_table th{background:var(--bg-alt) !important;font-family:var(--font-display) !important;font-weight:400 !important}
.woocommerce a.button,.woocommerce button.button{border-radius:var(--radius-full) !important;font-family:var(--font-body) !important;font-weight:800 !important;border:2px solid var(--text) !important;box-shadow:var(--shadow-pop) !important;transition:var(--transition) !important}
.woocommerce a.button:hover,.woocommerce button.button:hover{transform:translate(-2px,-2px) !important;box-shadow:var(--shadow-pop-lg) !important}
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce #respond input#submit.alt{background:var(--primary) !important;color:#fff !important}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{border:2px solid var(--text) !important;border-radius:var(--radius-sm) !important;padding:10px 14px !important;font-family:var(--font-body) !important;font-size:15px !important;background:var(--bg) !important;transition:box-shadow .15s !important}
.woocommerce form .form-row input.input-text:focus{outline:none !important;box-shadow:3px 3px 0 var(--primary) !important}
.woocommerce form .form-row label{font-weight:700 !important;font-family:var(--font-body) !important;color:var(--text) !important;margin-bottom:6px !important;display:block !important}
.woocommerce button[type=submit],.woocommerce input[type=submit]{background:var(--primary) !important;color:#fff !important;border:2px solid var(--text) !important;border-radius:var(--radius-full) !important;padding:12px 28px !important;font-family:var(--font-body) !important;font-weight:800 !important;font-size:15px !important;cursor:pointer !important;box-shadow:var(--shadow-pop) !important;transition:var(--transition) !important}
.woocommerce button[type=submit]:hover,.woocommerce input[type=submit]:hover{background:var(--text) !important;transform:translate(-2px,-2px) !important;box-shadow:var(--shadow-pop-lg) !important}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-radius:var(--radius-md) !important;border:2px solid var(--text) !important;font-family:var(--font-body) !important;font-weight:700 !important}
.woocommerce-message{background:#E5F9F6 !important;border-top-color:var(--accent) !important}
.woocommerce-info{background:#EDE9FE !important;border-top-color:var(--accent2) !important}
.woocommerce-error{background:#FFE5EC !important;border-top-color:var(--primary) !important}

/* ============================================================
   MY ACCOUNT PAGE (KeyChainPop style)
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation{background:var(--surface);border:2px solid var(--text);border-radius:var(--radius-md);box-shadow:var(--shadow-pop);overflow:hidden;margin-bottom:0}
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{display:block;padding:14px 20px;font-weight:700;color:var(--text);border-bottom:1px solid var(--bg-alt);transition:background .15s;text-decoration:none;font-family:var(--font-body)}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a{background:var(--primary);color:#fff}
.woocommerce-account .woocommerce-MyAccount-content{background:var(--surface);border:2px solid var(--text);border-radius:var(--radius-md);padding:30px;box-shadow:var(--shadow-pop)}
.woocommerce-account .u-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.woocommerce-account .u-columns .col-1,.woocommerce-account .u-columns .col-2{width:100% !important;float:none !important}
.keychainpop-account-dashboard .account-welcome-banner h2{font-family:var(--font-display)}
.keychainpop-account-dashboard .account-quick-links a{font-family:var(--font-body)}

/* ============================================================
   SIDEBAR
   ============================================================ */
.widget{margin-bottom:28px;background:var(--surface);border:2px solid var(--text);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-pop)}
.widget-title{font-size:18px;margin-bottom:18px;font-family:var(--font-display);padding-bottom:12px;border-bottom:2px solid var(--text)}
.widget ul li{padding:8px 0;border-bottom:1px solid var(--bg-alt);font-size:14px;font-weight:600}
.widget ul li:last-child{border-bottom:none}
.widget ul li a{color:var(--text)}
.widget ul li a:hover{color:var(--primary)}

/* ============================================================
   MY ACCOUNT / REGISTER PAGE
   ============================================================ */
.account-page{padding:60px 0}
.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;max-width:900px;margin:0 auto}
.account-box{background:var(--surface);border:2px solid var(--text);border-radius:var(--radius-md);padding:40px;box-shadow:var(--shadow-pop)}
.account-box-title{font-size:24px;margin-bottom:8px;font-family:var(--font-display)}
.account-box-sub{color:var(--text-muted);font-size:14px;margin-bottom:28px;font-weight:600}
.form-field{margin-bottom:20px}
.form-field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px;font-family:var(--font-body)}
.form-field input{width:100%;padding:10px 14px;border:2px solid var(--text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;outline:none;transition:box-shadow .15s;background:var(--bg)}
.form-field input:focus{box-shadow:3px 3px 0 var(--primary)}

/* ============================================================
   CUSTOM BANNER
   ============================================================ */
.custom-banner-section{padding:28px 0 0}
.custom-banner-img{width:100%;border-radius:var(--radius-md);object-fit:cover;max-height:380px;display:block;border:3px solid var(--text);box-shadow:var(--shadow-pop-lg)}

/* ============================================================
   MOBILE RESPONSIVE
   ============================================================ */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}.hero-inner{gap:40px}.aliexpress-card{grid-template-columns:1fr}}
@media(max-width:768px){
  .topbar .container{flex-direction:column;gap:4px;text-align:center}
  .header-inner{flex-wrap:wrap;gap:12px}
  .header-search{order:3;width:100%;max-width:100%}
  .main-nav ul{display:none;flex-direction:column;width:100%}
  .main-nav ul.active{display:flex}
  .mobile-menu-toggle{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .hero-image{display:none}
  .promo-inner{grid-template-columns:1fr;text-align:center}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .account-grid{grid-template-columns:1fr}
  .newsletter-box{padding:40px 24px}
  .newsletter-form{flex-direction:column}
  .newsletter-form input{border-right:2px solid rgba(255,255,255,.3);border-radius:var(--radius-full);margin-bottom:8px}
  .newsletter-form button{border-radius:var(--radius-full)}
  .woocommerce div.product{grid-template-columns:1fr}
  .woocommerce-account .u-columns{grid-template-columns:1fr}
  .benefits-inner{gap:20px}
}
@media(max-width:480px){
  .categories-grid{grid-template-columns:repeat(3,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .hero-actions{flex-direction:column}
  .hero-stats{flex-direction:column}
  .trust-grid{grid-template-columns:1fr}
  .hero-banner{padding:48px 0}
  .btn{padding:12px 20px;font-size:14px}
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.fade-in{animation:fadeInUp .5s ease forwards}
.float-anim{animation:float 3s ease-in-out infinite}
#scroll-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;background:var(--primary);color:#fff;border:2px solid var(--text);border-radius:50%;font-size:20px;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow-pop);transition:var(--transition);z-index:9999}
#scroll-top.visible{display:flex}
#scroll-top:hover{background:var(--text);transform:translate(-2px,-2px);box-shadow:var(--shadow-pop-lg)}
.whatsapp-float{position:fixed;bottom:82px;right:24px;width:52px;height:52px;background:#25D366;color:#fff;border-radius:50%;border:2px solid var(--text);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--shadow-pop);transition:var(--transition);z-index:9998;text-decoration:none}
.whatsapp-float:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-pop-lg);color:#fff}

/* ANNOUNCEMENT BAR */
.announcement-bar{background:var(--primary);color:#fff;text-align:center;padding:8px 20px;font-weight:700;font-size:13px;border-bottom:2px solid var(--text)}
.announcement-bar a{color:var(--secondary);text-decoration:underline}
