/*
Theme Name: labububox
Theme URI: https://labububox.com
Description: Authentic Labubu, Blind Boxes & Designer Toy Collectibles
Version: 1.0.0
Author: LABUBUBOX
Author URI: https://labububox.com
Text Domain: labububox
Requires at least: 6.5
Requires PHP: 8.0
*/

/* ===== DESIGN TOKENS ===== */
:root {
  --lb-bg: #ffffff;
  --lb-fg: #0a0a0a;
  --lb-muted: #71717a;
  --lb-border: #e4e4e7;
  --lb-border-strong: rgba(10,10,10,.10);
  --lb-accent: #7C3AED;
  --lb-accent-light: #8B5CF6;
  --lb-accent-bg: #F5F3FF;
  --lb-card: #ffffff;
  --lb-card-alt: #fafafa;
  --lb-soft: #f4f4f5;
  --lb-shadow: 0 1px 2px rgba(0,0,0,.05);
  --lb-shadow-md: 0 4px 12px rgba(0,0,0,.08);
  --lb-shadow-lg: 0 20px 50px rgba(0,0,0,.10);
  --lb-radius: 14px;
  --lb-radius-sm: 8px;
  --lb-radius-full: 9999px;
  --lb-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --lb-font-display: 'Space Grotesk', 'Inter', sans-serif;
  --lb-transition: .2s cubic-bezier(.4,0,.2,1);
}

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--lb-font);font-size:15px;line-height:1.6;color:var(--lb-fg);background:var(--lb-bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5,h6{font-family:var(--lb-font-display);font-weight:600;line-height:1.2;margin:0 0 .5em}
p{margin:0 0 1em}
ul{list-style:none;margin:0;padding:0}
button{cursor:pointer;font:inherit;border:none;background:none}
input,select,textarea{font:inherit}

.lb-container{max-width:1280px;margin:0 auto;padding:0 24px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

/* ===== HEADER ===== */
.lb-header{position:sticky;top:0;z-index:100;background:var(--lb-bg);border-bottom:1px solid var(--lb-border)}
.lb-topbar{padding:0 0}
.lb-topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
.lb-brand{display:flex;align-items:center;gap:10px;font-family:var(--lb-font-display);font-weight:700;font-size:20px;letter-spacing:-.02em;white-space:nowrap}
.lb-brand-badge{width:36px;height:36px;border-radius:10px;object-fit:cover}
.lb-brand-badge--fallback{background:var(--lb-accent);display:inline-block}
.lb-brand-text{color:var(--lb-fg)}

.lb-nav{display:flex;align-items:center}
.lb-nav-list{display:flex;gap:4px;align-items:center}
.lb-nav-list li a{display:block;padding:8px 14px;font-size:14px;font-weight:500;color:var(--lb-muted);border-radius:var(--lb-radius-sm);transition:var(--lb-transition)}
.lb-nav-list li a:hover{color:var(--lb-fg);background:var(--lb-soft)}

.lb-actions{display:flex;align-items:center;gap:8px}
.lb-pill{display:flex;align-items:center;gap:6px;background:var(--lb-soft);border-radius:var(--lb-radius-full);padding:6px 14px;font-size:13px;border:none;transition:var(--lb-transition)}
.lb-pill:focus-within{box-shadow:0 0 0 2px var(--lb-accent)}
.lb-pill input{border:none;background:none;outline:none;width:160px;font-size:13px;color:var(--lb-fg)}
.lb-pill input::placeholder{color:var(--lb-muted)}

.lb-iconbtn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--lb-radius-sm);transition:var(--lb-transition);position:relative}
.lb-iconbtn:hover{background:var(--lb-soft)}
.lb-cart-count{position:absolute;top:2px;right:2px;background:var(--lb-accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}

.lb-menu-toggle{display:none;flex-direction:column;gap:4px;padding:8px;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--lb-radius-sm)}
.lb-menu-toggle span:not(.screen-reader-text){display:block;width:18px;height:2px;background:var(--lb-fg);border-radius:1px;transition:var(--lb-transition)}

.lb-mobile-nav{background:var(--lb-bg);border-bottom:1px solid var(--lb-border)}
.lb-mobile-nav-inner{display:flex;flex-direction:column;padding:16px 0}
.lb-mobile-nav-inner li a{display:block;padding:12px 0;font-size:16px;font-weight:500;border-bottom:1px solid var(--lb-border)}

/* Announcement bar */
.lb-announce{background:var(--lb-fg);color:#fff;text-align:center;padding:8px 16px;font-size:12px;font-weight:500;letter-spacing:.03em}

/* ===== HERO ===== */
.lb-hero{position:relative;overflow:hidden;background:var(--lb-soft)}
.lb-hero-slides{display:flex;transition:transform .5s ease}
.lb-hero-slide{min-width:100%;position:relative}
.lb-hero-slide img{width:100%;height:520px;object-fit:cover}
.lb-hero-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(to right,rgba(0,0,0,.45) 0%,rgba(0,0,0,.1) 100%);text-align:center;padding:24px}
.lb-hero-overlay-inner{max-width:560px}
.lb-hero-overlay-title{font-family:var(--lb-font-display);font-size:clamp(32px,5vw,56px);font-weight:700;color:#fff;letter-spacing:-.03em;margin-bottom:12px;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.lb-hero-overlay-sub{font-size:clamp(15px,2vw,18px);color:rgba(255,255,255,.9);margin-bottom:24px}
.lb-hero-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.lb-hero-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:var(--lb-transition)}
.lb-hero-dot.active{background:#fff;transform:scale(1.2)}

/* ===== BUTTONS ===== */
.lb-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;font-size:13px;font-weight:600;border-radius:var(--lb-radius-full);border:1.5px solid var(--lb-border);color:var(--lb-fg);background:var(--lb-bg);transition:var(--lb-transition);letter-spacing:.01em;white-space:nowrap}
.lb-btn:hover{border-color:var(--lb-fg);background:var(--lb-fg);color:#fff}
.lb-btn-primary{background:var(--lb-accent);color:#fff;border-color:var(--lb-accent)}
.lb-btn-primary:hover{background:var(--lb-accent-light);border-color:var(--lb-accent-light)}
.lb-btn-ghost{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.lb-btn-ghost:hover{background:rgba(255,255,255,.15);border-color:#fff}

/* ===== TRUST BAR ===== */
.lb-trust-bar{border-bottom:1px solid var(--lb-border);padding:14px 0}
.lb-trust-bar-inner{display:flex;justify-content:center;gap:32px;font-size:13px;color:var(--lb-muted);flex-wrap:wrap}

/* ===== SECTIONS ===== */
.lb-section{padding:64px 0}
.lb-section-tight{padding:48px 0}
.lb-section-title{font-family:var(--lb-font-display);font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.02em}
.lb-section-sub{font-size:14px;color:var(--lb-muted);margin-top:4px}
.lb-section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;gap:16px}
.lb-section-head-tight{margin-bottom:24px}

/* ===== PRODUCT GRID (WooCommerce override) ===== */
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:20px!important;padding:0!important;margin:0!important;list-style:none!important}
.woocommerce ul.products li.product{margin:0!important;padding:0!important;width:auto!important;float:none!important}
.woocommerce ul.products li.product a img{border-radius:var(--lb-radius)!important;aspect-ratio:1;object-fit:cover!important;transition:transform var(--lb-transition)!important;background:var(--lb-soft)}
.woocommerce ul.products li.product:hover a img{transform:scale(1.03)!important}
.woocommerce ul.products li.product a{text-decoration:none!important}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--lb-font)!important;font-size:14px!important;font-weight:500!important;color:var(--lb-fg)!important;padding:10px 0 2px!important;line-height:1.4!important}
.woocommerce ul.products li.product .price{font-size:15px!important;font-weight:600!important;color:var(--lb-fg)!important}
.woocommerce ul.products li.product .price del{color:var(--lb-muted)!important;font-weight:400!important}
.woocommerce ul.products li.product .price ins{text-decoration:none!important;color:var(--lb-accent)!important}
.woocommerce ul.products li.product .button,.woocommerce ul.products li.product .add_to_cart_button{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:100%!important;padding:10px 16px!important;font-size:13px!important;font-weight:600!important;border-radius:var(--lb-radius-sm)!important;background:var(--lb-fg)!important;color:#fff!important;border:none!important;margin-top:8px!important;transition:var(--lb-transition)!important;letter-spacing:.01em!important}
.woocommerce ul.products li.product .button:hover,.woocommerce ul.products li.product .add_to_cart_button:hover{background:var(--lb-accent)!important}
.woocommerce ul.products li.product .onsale{background:var(--lb-accent)!important;color:#fff!important;border-radius:var(--lb-radius-full)!important;font-size:11px!important;font-weight:700!important;padding:4px 10px!important;top:10px!important;right:10px!important;left:auto!important;line-height:1.4!important}

/* Quick view badge */
.woocommerce ul.products li.product{position:relative;overflow:hidden}
.woocommerce ul.products li.product .lb-badge-new{position:absolute;top:10px;left:10px;background:var(--lb-accent);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--lb-radius-full);z-index:2;text-transform:uppercase;letter-spacing:.05em}

/* ===== SHOP BY CHARACTER ===== */
.lb-char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.lb-char-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;background:var(--lb-card);border:1px solid var(--lb-border);border-radius:var(--lb-radius);transition:var(--lb-transition);text-align:center}
.lb-char-card:hover{border-color:var(--lb-accent);box-shadow:var(--lb-shadow-md);transform:translateY(-2px)}
.lb-char-card img{width:100px;height:100px;border-radius:50%;object-fit:cover;background:var(--lb-soft)}
.lb-char-card strong{font-size:14px;font-weight:600}
.lb-char-card span{font-size:12px;color:var(--lb-muted)}

/* ===== CATEGORY VISUAL CARDS ===== */
.lb-cat-visual-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.lb-cat-visual-card{position:relative;border-radius:var(--lb-radius);overflow:hidden;aspect-ratio:1;display:flex;align-items:flex-end}
.lb-cat-visual-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--lb-transition)}
.lb-cat-visual-card:hover img{transform:scale(1.05)}
.lb-cat-visual-label{position:relative;z-index:1;width:100%;padding:16px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;display:flex;flex-direction:column;gap:2px}
.lb-cat-visual-label strong{font-size:16px;font-weight:600}
.lb-cat-visual-label span{font-size:12px;opacity:.8}

/* ===== NEWS CARDS ===== */
.lb-news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lb-news-grid--home{grid-template-columns:repeat(3,1fr)}
.lb-news-card{border-radius:var(--lb-radius);overflow:hidden;border:1px solid var(--lb-border);transition:var(--lb-transition);background:var(--lb-card)}
.lb-news-card:hover{box-shadow:var(--lb-shadow-md);transform:translateY(-2px)}
.lb-news-card-link{display:flex;flex-direction:column;height:100%}
.lb-news-card-media{aspect-ratio:16/9;overflow:hidden;background:var(--lb-soft)}
.lb-news-card-media--placeholder{background:linear-gradient(135deg,var(--lb-accent-bg),var(--lb-soft))}
.lb-news-card-img{width:100%;height:100%;object-fit:cover;transition:transform var(--lb-transition)}
.lb-news-card:hover .lb-news-card-img{transform:scale(1.04)}
.lb-news-card-body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.lb-news-card-kicker{font-size:11px;font-weight:600;color:var(--lb-accent);text-transform:uppercase;letter-spacing:.06em}
.lb-news-card-title{font-size:15px;font-weight:600;line-height:1.35}
.lb-news-card-excerpt{font-size:13px;color:var(--lb-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lb-news-card-date{font-size:12px;color:var(--lb-muted);margin-top:auto;padding-top:8px}

/* ===== ABOUT / WHY SECTION ===== */
.lb-about-row{display:flex;align-items:center;gap:48px}
.lb-about-text{flex:1}
.lb-about-text h2{font-size:24px;margin-bottom:12px}
.lb-about-text p{color:var(--lb-muted);font-size:15px;line-height:1.7}
.lb-about-badges{display:flex;gap:24px}
.lb-about-badge{text-align:center;padding:20px;background:var(--lb-soft);border-radius:var(--lb-radius);min-width:110px}
.lb-about-badge strong{display:block;font-family:var(--lb-font-display);font-size:24px;font-weight:700;color:var(--lb-accent)}
.lb-about-badge span{font-size:12px;color:var(--lb-muted);margin-top:4px;display:block}

/* ===== SEO BLOCK ===== */
.lb-seo-block{background:var(--lb-soft);border-radius:0}
.lb-seo-text{max-width:800px;font-size:14px;color:var(--lb-muted);line-height:1.8}
.lb-seo-text a{color:var(--lb-accent);text-decoration:underline;text-underline-offset:2px}
.lb-seo-text strong{color:var(--lb-fg)}

/* ===== FOOTER ===== */
.lb-footer{background:var(--lb-fg);color:rgba(255,255,255,.7);padding:56px 0 0}
.lb-footer a{color:rgba(255,255,255,.7);transition:var(--lb-transition)}
.lb-footer a:hover{color:#fff}
.lb-footer-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:32px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.lb-footer-col h4{color:#fff;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}
.lb-footer-col ul li{margin-bottom:8px}
.lb-footer-col ul li a{font-size:13px}
.lb-footer-brand-desc{font-size:13px;line-height:1.7;margin-top:8px;max-width:280px}
.lb-footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:20px 0;font-size:12px;color:rgba(255,255,255,.4)}

/* Newsletter in footer */
.lb-newsletter{margin-top:24px}
.lb-newsletter-form{display:flex;gap:8px}
.lb-newsletter-form input[type="email"]{flex:1;padding:10px 14px;border-radius:var(--lb-radius-sm);border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-size:13px}
.lb-newsletter-form input[type="email"]::placeholder{color:rgba(255,255,255,.4)}
.lb-newsletter-form button{padding:10px 20px;border-radius:var(--lb-radius-sm);background:var(--lb-accent);color:#fff;font-size:13px;font-weight:600;border:none;transition:var(--lb-transition)}
.lb-newsletter-form button:hover{background:var(--lb-accent-light)}

/* ===== ARCHIVE / SHOP PAGE ===== */
.lb-shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.lb-shop-count{font-size:14px;color:var(--lb-muted)}
.lb-cat-chips{display:flex;gap:8px;flex-wrap:wrap}
.lb-cat-chip{display:inline-flex;padding:6px 14px;font-size:12px;font-weight:500;border-radius:var(--lb-radius-full);border:1px solid var(--lb-border);color:var(--lb-muted);transition:var(--lb-transition)}
.lb-cat-chip:hover,.lb-cat-chip.active{background:var(--lb-fg);color:#fff;border-color:var(--lb-fg)}

.lb-shop-layout{display:grid;grid-template-columns:240px 1fr;gap:32px}
.lb-sidebar{position:sticky;top:80px;align-self:start}
.lb-sidebar section{margin-bottom:24px}
.lb-sidebar h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;color:var(--lb-fg)}

/* ===== SINGLE NEWS ===== */
.lb-news-single{max-width:760px;margin:0 auto;padding:48px 24px}
.lb-news-single h1{font-size:clamp(24px,4vw,36px);margin-bottom:16px}
.lb-news-single .lb-news-meta{font-size:13px;color:var(--lb-muted);margin-bottom:32px;display:flex;gap:16px}
.lb-news-single .entry-content{font-size:16px;line-height:1.8;color:var(--lb-fg)}
.lb-news-single .entry-content h2{font-size:22px;margin:32px 0 12px}
.lb-news-single .entry-content h3{font-size:18px;margin:24px 0 8px}
.lb-news-single .entry-content a{color:var(--lb-accent);text-decoration:underline;text-underline-offset:2px}
.lb-news-single .entry-content img{border-radius:var(--lb-radius);margin:24px 0}

/* Related posts */
.lb-news-related{margin-top:48px;padding-top:32px;border-top:1px solid var(--lb-border)}
.lb-news-related-title{font-size:20px;margin-bottom:20px}
.lb-news-related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.lb-news-related-card{border-radius:var(--lb-radius);overflow:hidden;border:1px solid var(--lb-border);transition:var(--lb-transition)}
.lb-news-related-card:hover{box-shadow:var(--lb-shadow-md)}
.lb-news-related-media{aspect-ratio:16/9;overflow:hidden}
.lb-news-related-img{width:100%;height:100%;object-fit:cover}
.lb-news-related-body{padding:12px}
.lb-news-related-kicker{font-size:10px;font-weight:600;color:var(--lb-accent);text-transform:uppercase;letter-spacing:.06em}
.lb-news-related-name{font-size:13px;font-weight:500;display:block;margin-top:4px;line-height:1.35}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .lb-nav{display:none}
  .lb-menu-toggle{display:flex}
  .woocommerce ul.products{grid-template-columns:repeat(3,1fr)!important}
  .lb-cat-visual-grid{grid-template-columns:repeat(2,1fr)}
  .lb-news-grid,.lb-news-grid--home{grid-template-columns:repeat(2,1fr)}
  .lb-footer-grid{grid-template-columns:repeat(2,1fr)}
  .lb-shop-layout{grid-template-columns:1fr}
  .lb-about-row{flex-direction:column;gap:24px}
  .lb-hero-slide img{height:380px}
  .lb-news-related-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}
  .lb-cat-visual-grid{grid-template-columns:1fr 1fr}
  .lb-news-grid,.lb-news-grid--home{grid-template-columns:1fr}
  .lb-footer-grid{grid-template-columns:1fr}
  .lb-trust-bar-inner{flex-direction:column;gap:8px}
  .lb-about-badges{flex-direction:row;gap:12px}
  .lb-about-badge{min-width:0;flex:1}
  .lb-hero-slide img{height:280px}
  .lb-hero-overlay-title{font-size:28px}
  .lb-section{padding:40px 0}
  .lb-section-tight{padding:32px 0}
  .lb-topbar-inner{height:56px}
  .lb-pill input{width:100px}
  .lb-news-related-grid{grid-template-columns:1fr 1fr}
  .lb-char-grid{grid-template-columns:repeat(2,1fr)}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ===== WooCommerce single product overrides ===== */
.woocommerce div.product{padding:32px 0}
.woocommerce div.product div.images{border-radius:var(--lb-radius);overflow:hidden}
.woocommerce div.product .product_title{font-family:var(--lb-font-display);font-size:28px;font-weight:700}
.woocommerce div.product p.price{font-size:24px;font-weight:700;color:var(--lb-fg)}
.woocommerce div.product .single_add_to_cart_button{background:var(--lb-accent)!important;border-radius:var(--lb-radius-sm)!important;padding:14px 32px!important;font-size:15px!important;font-weight:600!important;transition:var(--lb-transition)!important}
.woocommerce div.product .single_add_to_cart_button:hover{background:var(--lb-accent-light)!important}

/* WooCommerce notices */
.woocommerce-message,.woocommerce-info{border-top-color:var(--lb-accent)!important;border-radius:var(--lb-radius-sm)}
.woocommerce-message::before,.woocommerce-info::before{color:var(--lb-accent)!important}
