/*
Theme Name: Digitide Store
Theme URI: https://digitidestore.com
Author: Adarsh Sachan
Author URI: https://digitidestore.com
Description: Premium digital products store theme for WooCommerce. Sell ebooks, templates, courses, and more. Optimized for AdSense and SEO.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.4
WC requires at least: 7.0
WC tested up to: 8.5
License: GNU General Public License v2 or later
Text Domain: digitide-store
Tags: e-commerce, digital-products, blog, woocommerce, custom-colors
*/

:root {
  --pri:#6C63FF; --pri-d:#5a52e0; --sec:#2D2B55; --acc:#FF6B6B; --acc-d:#e55555;
  --grn:#10b981; --ylw:#f59e0b; --bg:#F8F9FF; --white:#fff;
  --txt:#2D3748; --muted:#718096; --border:#E2E8F0;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --disp:'Poppins',var(--font);
  --r-sm:6px; --r-md:12px; --r-lg:20px; --r-full:9999px;
  --sh-sm:0 1px 3px rgba(0,0,0,.08); --sh-md:0 4px 16px rgba(108,99,255,.12);
  --sh-lg:0 8px 32px rgba(108,99,255,.18); --sh-xl:0 20px 60px rgba(108,99,255,.22);
  --tr:.3s cubic-bezier(.4,0,.2,1); --cont:1200px; --hh:70px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--txt);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--pri);text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--pri-d)}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
h1,h2,h3,h4,h5,h6{font-family:var(--disp);color:var(--sec);line-height:1.3;font-weight:700}
h1{font-size:clamp(2rem,4vw,3rem)}h2{font-size:clamp(1.5rem,3vw,2.25rem)}
h3{font-size:clamp(1.125rem,2vw,1.5rem)}p{margin-bottom:1rem}
.container{max-width:var(--cont);margin:0 auto;padding:0 1.5rem}
.section-pad{padding:80px 0}.section-pad-sm{padding:48px 0}
.text-center{text-align:center}.text-muted{color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:var(--r-md);font-weight:600;font-size:.9375rem;transition:all var(--tr);cursor:pointer;border:2px solid transparent;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--pri);color:#fff;box-shadow:0 4px 15px rgba(108,99,255,.35)}
.btn-primary:hover{background:var(--pri-d);color:#fff;transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn-accent{background:var(--acc);color:#fff;box-shadow:0 4px 15px rgba(255,107,107,.35)}
.btn-accent:hover{background:var(--acc-d);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;border-color:var(--pri);color:var(--pri)}
.btn-outline:hover{background:var(--pri);color:#fff}
.btn-white{background:#fff;color:var(--pri);box-shadow:var(--sh-md)}
.btn-white:hover{background:var(--bg);color:var(--pri-d);transform:translateY(-2px)}
.btn-sm{padding:.5rem 1.25rem;font-size:.875rem;border-radius:var(--r-sm)}
.btn-lg{padding:1rem 2.5rem;font-size:1.0625rem}.btn-block{width:100%}

/* Badge */
.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--r-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.badge-primary{background:rgba(108,99,255,.12);color:var(--pri)}
.badge-accent{background:rgba(255,107,107,.12);color:var(--acc)}
.badge-success{background:rgba(16,185,129,.12);color:var(--grn)}

/* Announcement */
.ann-bar{background:linear-gradient(90deg,var(--pri),var(--acc));color:#fff;text-align:center;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;letter-spacing:.03em}
.ann-bar a{color:#fff;text-decoration:underline}

/* Header */
.site-header{background:#fff;position:sticky;top:0;z-index:1000;box-shadow:0 2px 20px rgba(0,0,0,.08);height:var(--hh)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:2rem}
.site-logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0;text-decoration:none}
.site-logo img{height:40px;width:auto}
.logo-text{font-family:var(--disp);font-size:1.5rem;font-weight:800}
.logo-text .logo-d{color:var(--pri)}.logo-text .logo-s{color:var(--sec)}
.header-search{flex:1;max-width:480px;position:relative}
.header-search input{width:100%;padding:.625rem 3rem .625rem 1.25rem;border:2px solid var(--border);border-radius:var(--r-full);font-size:.9375rem;outline:none;transition:border-color var(--tr);background:var(--bg)}
.header-search input:focus{border-color:var(--pri);background:#fff}
.header-search button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--muted)}
.header-search button:hover{color:var(--pri)}
.header-actions{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}
.h-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;color:var(--txt);font-size:.75rem;font-weight:500;transition:color var(--tr);position:relative;text-decoration:none}
.h-btn:hover{color:var(--pri)}.h-btn svg{width:22px;height:22px}
.cart-count{position:absolute;top:-6px;right:-8px;background:var(--acc);color:#fff;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700}

/* Nav */
.site-nav{background:var(--sec)}
.site-nav ul{display:flex;align-items:center}
.site-nav ul li a{display:block;padding:.75rem 1.25rem;color:rgba(255,255,255,.85);font-size:.875rem;font-weight:500;transition:all var(--tr);position:relative}
.site-nav ul li a::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:3px;background:var(--pri);transition:all var(--tr)}
.site-nav ul li a:hover,.site-nav ul li.current-menu-item a{color:#fff}
.site-nav ul li a:hover::after,.site-nav ul li.current-menu-item a::after{left:0;right:0}

.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem;color:var(--txt)}
.mobile-menu-toggle span{display:block;width:24px;height:2px;background:currentColor;border-radius:2px;transition:var(--tr)}

/* Hero */
.hero{background:linear-gradient(135deg,var(--sec) 0%,#3d3a7c 50%,var(--pri) 100%);padding:80px 0 100px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(255,107,107,.15),transparent 60%)}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);color:#fff;padding:.4rem 1rem;border-radius:var(--r-full);font-size:.8125rem;font-weight:600;margin-bottom:1.25rem;border:1px solid rgba(255,255,255,.2)}
.hero-title{color:#fff;margin-bottom:1.25rem;line-height:1.2}
.hero-title em{font-style:normal;color:#a5b4fc}
.hero-desc{color:rgba(255,255,255,.8);font-size:1.0625rem;margin-bottom:2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.15)}
.stat-num{font-size:1.75rem;font-weight:800;color:#fff;line-height:1}
.stat-lbl{font-size:.8rem;color:rgba(255,255,255,.65);margin-top:.25rem}
.hero-visual{display:flex;align-items:center;justify-content:center}
.floating-cards{position:relative;width:340px;height:380px}
.fcard{position:absolute;background:#fff;border-radius:var(--r-lg);padding:1.5rem;box-shadow:var(--sh-xl);width:260px}
.fcard:nth-child(1){top:0;right:0;transform:rotate(6deg)}
.fcard:nth-child(2){top:50px;left:0;transform:rotate(-4deg);z-index:2}
.fcard:nth-child(3){bottom:0;right:20px;transform:rotate(2deg);z-index:3}
.fcard-icon{width:44px;height:44px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--pri),var(--acc));display:flex;align-items:center;justify-content:center;margin-bottom:.875rem;color:#fff;font-size:1.25rem}
.fcard-title{font-size:.875rem;font-weight:700;color:var(--sec);margin-bottom:.25rem}
.fcard-price{font-size:1.125rem;font-weight:800;color:var(--pri)}

/* Section header */
.sec-hdr{text-align:center;margin-bottom:3rem}
.sec-hdr .badge{margin-bottom:.75rem}
.sec-hdr h2{margin-bottom:.75rem}
.sec-hdr p{color:var(--muted);font-size:1.0625rem;max-width:560px;margin:0 auto}

/* Category Grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.cat-card{background:#fff;border-radius:var(--r-lg);padding:2rem 1.5rem;text-align:center;border:2px solid transparent;transition:all var(--tr);box-shadow:var(--sh-sm);text-decoration:none;display:block}
.cat-card:hover{border-color:var(--pri);transform:translateY(-4px);box-shadow:var(--sh-lg)}
.cat-icon{width:64px;height:64px;border-radius:var(--r-lg);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:1.75rem}
.cat-name{font-weight:700;color:var(--sec);font-size:.9375rem;margin-bottom:.25rem}
.cat-count{font-size:.8125rem;color:var(--muted)}

/* Products */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.prod-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--tr);display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.prod-thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,#f0f0ff,#ffe8e8)}
.prod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.prod-card:hover .prod-thumb img{transform:scale(1.05)}
.prod-badge{position:absolute;top:.75rem;left:.75rem}
.prod-wl{position:absolute;top:.75rem;right:.75rem;width:34px;height:34px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);opacity:0;transition:opacity var(--tr);color:var(--muted);cursor:pointer}
.prod-card:hover .prod-wl{opacity:1}.prod-wl:hover{color:var(--acc)}
.prod-info{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.prod-cat{font-size:.75rem;font-weight:600;color:var(--pri);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.prod-title{font-size:1rem;font-weight:700;color:var(--sec);margin-bottom:.75rem;line-height:1.4;flex:1}
.prod-title a{color:inherit}.prod-title a:hover{color:var(--pri)}
.prod-stars{display:flex;align-items:center;gap:.4rem;margin-bottom:.75rem}
.stars{color:#f59e0b;font-size:.875rem}.rating-cnt{font-size:.8rem;color:var(--muted)}
.prod-price{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}
.price-now{font-size:1.375rem;font-weight:800;color:var(--pri)}
.price-was{font-size:.9rem;color:var(--muted);text-decoration:line-through}
.price-off{font-size:.8rem;font-weight:700;color:var(--grn);background:rgba(16,185,129,.1);padding:.15rem .5rem;border-radius:var(--r-sm)}
.prod-actions{display:flex;gap:.5rem}
.prod-actions .btn{flex:1;padding:.625rem;font-size:.875rem}

/* Promo banner */
.promo-banner{background:linear-gradient(135deg,#FF6B6B,#FF8E53);border-radius:var(--r-lg);padding:3rem 2.5rem;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;color:#fff;position:relative;overflow:hidden}
.promo-banner::before{content:'';position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.1)}
.promo-title{font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:.5rem}
.promo-desc{color:rgba(255,255,255,.85);margin-bottom:0}

/* Features strip */
.feat-strip{background:var(--sec)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.feat-item{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem;border-right:1px solid rgba(255,255,255,.1)}
.feat-item:last-child{border-right:none}
.feat-icon{width:44px;height:44px;background:rgba(108,99,255,.3);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#a5b4fc;flex-shrink:0}
.feat-title{font-size:.875rem;font-weight:700;color:#fff}
.feat-desc{font-size:.8rem;color:rgba(255,255,255,.6)}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.post-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--tr)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.post-thumb{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,#f0f0ff,#e8f4ff)}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .post-thumb img{transform:scale(1.05)}
.post-body{padding:1.5rem}
.post-meta{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}
.post-cat{font-size:.75rem;font-weight:700;color:var(--pri);text-transform:uppercase;letter-spacing:.05em}
.post-date{font-size:.8rem;color:var(--muted)}
.post-title{font-size:1.0625rem;font-weight:700;color:var(--sec);margin-bottom:.75rem;line-height:1.4}
.post-title a{color:inherit}.post-title a:hover{color:var(--pri)}
.post-excerpt{font-size:.9rem;color:var(--muted);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.post-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border)}
.read-more{font-size:.8125rem;font-weight:600;color:var(--pri)}.read-more:hover{color:var(--pri-d)}

/* Testimonials */
.testi-bg{background:linear-gradient(135deg,var(--sec),#3d3a7c)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testi-card{background:rgba(255,255,255,.08);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:2rem}
.testi-stars{color:#f59e0b;font-size:1.1rem;margin-bottom:1rem}
.testi-text{color:rgba(255,255,255,.85);font-size:.9375rem;font-style:italic;margin-bottom:1.5rem;line-height:1.7}
.testi-author{display:flex;align-items:center;gap:.75rem}
.testi-av{width:44px;height:44px;border-radius:50%;background:var(--pri);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem;flex-shrink:0}
.testi-name{font-weight:700;color:#fff;font-size:.9375rem}
.testi-role{font-size:.8rem;color:rgba(255,255,255,.55)}

/* Newsletter */
.nl-section{background:#fff}
.nl-inner{background:linear-gradient(135deg,rgba(108,99,255,.08),rgba(255,107,107,.06));border-radius:var(--r-lg);padding:4rem 3rem;text-align:center;border:1px solid rgba(108,99,255,.15)}
.nl-form{display:flex;gap:1rem;max-width:480px;margin:2rem auto 0}
.nl-form input{flex:1;padding:.875rem 1.25rem;border:2px solid var(--border);border-radius:var(--r-md);font-size:1rem;outline:none;transition:border-color var(--tr)}
.nl-form input:focus{border-color:var(--pri)}

/* Ad zones */
.ad-zone{background:#f9f9f9;border:2px dashed var(--border);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:.8rem}
.ad-zone-leader{min-height:90px;margin:1.5rem 0}
.ad-zone-rect{min-height:250px;margin:1rem 0}
.ad-zone-sidebar{min-height:280px;margin-bottom:1.5rem}

/* Single post/page */
.single-wrap{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start;padding:3rem 0}
.single-content{min-width:0}
.post-hdr{margin-bottom:2rem}
.post-hdr h1{margin-bottom:1rem}
.post-hdr .post-meta{margin-bottom:1rem;flex-wrap:wrap}
.feat-img{border-radius:var(--r-lg);overflow:hidden;margin-bottom:2rem;aspect-ratio:16/9}
.feat-img img{width:100%;height:100%;object-fit:cover}
.entry-content{font-size:1.0625rem;line-height:1.85}
.entry-content h2,.entry-content h3,.entry-content h4{margin:1.75rem 0 .75rem}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1rem}
.entry-content ul{list-style:disc}.entry-content ol{list-style:decimal}
.entry-content blockquote{border-left:4px solid var(--pri);padding:1rem 1.5rem;margin:1.5rem 0;background:rgba(108,99,255,.06);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic}
.entry-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.entry-content table th,.entry-content table td{border:1px solid var(--border);padding:.75rem 1rem}
.entry-content table th{background:var(--pri);color:#fff}
.entry-content a{color:var(--pri);text-decoration:underline}
.entry-content img{border-radius:var(--r-md);margin:1.5rem 0}

/* Post tags */
.post-tags{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.post-tags strong{color:var(--txt)}
.tag-link{background:rgba(108,99,255,.1);color:var(--pri);padding:.3rem .875rem;border-radius:var(--r-full);font-size:.8125rem;font-weight:500;transition:all var(--tr)}
.tag-link:hover{background:var(--pri);color:#fff}

/* Author box */
.author-box{background:#fff;border-radius:var(--r-lg);padding:2rem;margin-top:2rem;display:flex;gap:1.5rem;align-items:flex-start;box-shadow:var(--sh-sm)}
.author-av{width:80px;height:80px;border-radius:50%;background:var(--pri);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#fff;flex-shrink:0}
.author-name{font-size:1.0625rem;font-weight:700;color:var(--sec);margin-bottom:.25rem}
.author-bio{font-size:.9375rem;color:var(--muted);margin:0}

/* Sidebar */
.sidebar{position:sticky;top:calc(var(--hh) + 2rem)}
.widget{background:#fff;border-radius:var(--r-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--sh-sm)}
.widget-title{font-size:1rem;font-weight:700;color:var(--sec);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:.5rem}
.widget-title::before{content:'';width:4px;height:18px;background:var(--pri);border-radius:2px}
.widget ul li{padding:.5rem 0;border-bottom:1px solid var(--border)}
.widget ul li:last-child{border-bottom:none}
.widget ul li a{color:var(--txt);font-size:.9rem;display:flex;justify-content:space-between}
.widget ul li a:hover{color:var(--pri)}

/* Breadcrumbs */
.breadcrumbs{padding:1rem 0;font-size:.875rem;color:var(--muted)}
.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--pri)}
.breadcrumbs .sep{margin:0 .5rem}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:.5rem;padding:2rem 0}
.pagination a,.pagination span{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:.875rem;font-weight:600;border:2px solid var(--border);color:var(--txt);transition:all var(--tr)}
.pagination .current,.pagination a:hover{background:var(--pri);border-color:var(--pri);color:#fff}

/* WooCommerce archive */
.woo-wrap{display:grid;grid-template-columns:260px 1fr;gap:2.5rem;padding:2.5rem 0;align-items:start}
.woo-sidebar{position:sticky;top:calc(var(--hh) + 1.5rem)}
.filter-box{background:#fff;border-radius:var(--r-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--sh-sm)}
.filter-ttl{font-size:1rem;font-weight:700;color:var(--sec);margin-bottom:1rem}
.filter-list{display:flex;flex-direction:column;gap:.5rem}
.filter-list label{display:flex;align-items:center;gap:.75rem;font-size:.9rem;cursor:pointer}
.filter-list input[type=checkbox]{accent-color:var(--pri);width:16px;height:16px}
.sort-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;background:#fff;padding:.875rem 1.25rem;border-radius:var(--r-md);box-shadow:var(--sh-sm)}
.results-count{font-size:.9rem;color:var(--muted)}
.sort-select{border:1px solid var(--border);border-radius:var(--r-sm);padding:.4rem .875rem;font-size:.875rem;outline:none}

/* WooCommerce single product */
.sprod-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:3rem 0;align-items:start}
.gallery-main{aspect-ratio:1;border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--sh-md)}
.gallery-main img{width:100%;height:100%;object-fit:contain;padding:1rem}
.gallery-thumbs{display:flex;gap:.75rem;margin-top:1rem}
.gallery-thumbs img{width:72px;height:72px;object-fit:cover;border-radius:var(--r-sm);border:2px solid transparent;cursor:pointer;transition:border-color var(--tr)}
.gallery-thumbs img.active,.gallery-thumbs img:hover{border-color:var(--pri)}
.sprod-price{display:flex;align-items:baseline;gap:1rem;margin:1.25rem 0}
.sprod-price .price-now{font-size:2rem}
.highlights{list-style:none;padding:0;margin:1.25rem 0;display:flex;flex-direction:column;gap:.5rem}
.highlights li{display:flex;align-items:center;gap:.625rem;font-size:.9375rem}
.highlights li::before{content:'✓';color:var(--grn);font-weight:700}
.buy-actions{display:flex;gap:1rem;margin:1.5rem 0}
.buy-actions .btn{flex:1}

/* Cart */
.cart-wrap{padding:2.5rem 0;display:grid;grid-template-columns:1fr 360px;gap:2.5rem;align-items:start}
.cart-tbl{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}
.cart-tbl table{width:100%;border-collapse:collapse}
.cart-tbl th{background:var(--bg);padding:1rem 1.5rem;text-align:left;font-size:.875rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}
.cart-tbl td{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);vertical-align:middle}
.cart-tbl tr:last-child td{border-bottom:none}
.cart-prod-info{display:flex;align-items:center;gap:1rem}
.cart-thumb{width:72px;height:72px;border-radius:var(--r-md);object-fit:cover;border:1px solid var(--border)}
.cart-prod-name{font-weight:600;color:var(--sec)}
.cart-summary{background:#fff;border-radius:var(--r-lg);padding:1.5rem;box-shadow:var(--sh-sm)}
.cs-row{display:flex;justify-content:space-between;padding:.625rem 0;border-bottom:1px solid var(--border);font-size:.9375rem}
.cs-row:last-child{border-bottom:none;font-weight:700;font-size:1.0625rem;color:var(--sec);padding-top:1rem}

/* Forms */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--txt);margin-bottom:.5rem}
.form-ctrl{width:100%;padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--r-md);font-size:.9375rem;outline:none;transition:border-color var(--tr);background:#fff;color:var(--txt);font-family:inherit}
.form-ctrl:focus{border-color:var(--pri)}
textarea.form-ctrl{resize:vertical;min-height:120px}

/* Footer */
.site-footer{background:var(--sec)}
.footer-top{padding:60px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
.footer-about{color:rgba(255,255,255,.6);font-size:.9rem;margin:1rem 0 1.5rem;line-height:1.7}
.social-links{display:flex;gap:.75rem}
.social-link{width:38px;height:38px;background:rgba(255,255,255,.1);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all var(--tr);font-size:.9rem;font-weight:700}
.social-link:hover{background:var(--pri);color:#fff;transform:translateY(-2px)}
.footer-widget-title{font-size:.9375rem;font-weight:700;color:#fff;margin-bottom:1.25rem}
.footer-links{display:flex;flex-direction:column;gap:.625rem}
.footer-links a{color:rgba(255,255,255,.6);font-size:.9rem;transition:color var(--tr)}
.footer-links a:hover{color:var(--pri)}
.footer-contact{display:flex;flex-direction:column;gap:.875rem}
.fc-item{display:flex;align-items:flex-start;gap:.625rem;font-size:.875rem;color:rgba(255,255,255,.65)}
.footer-bottom{background:rgba(0,0,0,.2);padding:1.25rem 0}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer-legal-links{display:flex;gap:1.5rem}
.footer-legal-links a{font-size:.8125rem;color:rgba(255,255,255,.5);transition:color var(--tr)}
.footer-legal-links a:hover{color:rgba(255,255,255,.9)}
.pay-icons{display:flex;gap:.5rem;align-items:center}
.pay-icons span{background:rgba(255,255,255,.15);color:#fff;font-size:.6875rem;font-weight:700;padding:.25rem .625rem;border-radius:var(--r-sm);letter-spacing:.05em}

/* Scroll top */
#scroll-top{position:fixed;bottom:2rem;right:2rem;width:46px;height:46px;background:var(--pri);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--sh-lg);cursor:pointer;opacity:0;visibility:hidden;transition:all var(--tr);z-index:999}
#scroll-top.visible{opacity:1;visibility:visible}
#scroll-top:hover{background:var(--pri-d);transform:translateY(-3px)}

/* Mobile drawer */
.mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1099;opacity:0;visibility:hidden;transition:all var(--tr)}
.mob-overlay.open{opacity:1;visibility:visible}
.mob-drawer{position:fixed;top:0;left:-100%;width:280px;height:100vh;background:#fff;z-index:1100;padding:1.5rem;overflow-y:auto;transition:left .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-xl)}
.mob-drawer.open{left:0}
.mob-close{position:absolute;top:1rem;right:1rem;padding:.5rem;color:var(--txt);font-size:1.25rem;line-height:1}
.mob-nav{margin-top:2rem}
.mob-nav ul{display:flex;flex-direction:column}
.mob-nav ul li a{display:block;padding:.875rem 0;color:var(--txt);font-weight:500;border-bottom:1px solid var(--border)}

/* Toast */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);background:var(--sec);color:#fff;padding:.875rem 1.75rem;border-radius:var(--r-md);font-size:.9375rem;box-shadow:var(--sh-xl);transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:9999;pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Page hero */
.page-hero{background:linear-gradient(135deg,var(--sec),#3d3a7c);padding:3rem 0}
.page-hero h1{color:#fff;font-size:2rem;margin-bottom:.5rem}
.page-hero p{color:rgba(255,255,255,.7);margin:0}

/* Legal */
.legal-wrap{max-width:820px;margin:0 auto;padding:3rem 0}
.legal-wrap h2{margin-top:2.5rem;margin-bottom:.75rem;font-size:1.375rem}
.legal-wrap h3{margin-top:1.75rem;margin-bottom:.5rem;font-size:1.1rem;color:var(--txt)}
.legal-wrap ul{list-style:disc;padding-left:1.5rem;margin:1rem 0}
.legal-wrap ul li{margin-bottom:.5rem}
.legal-updated{background:rgba(108,99,255,.08);border:1px solid rgba(108,99,255,.2);border-radius:var(--r-md);padding:.75rem 1rem;font-size:.875rem;color:var(--pri);margin-bottom:2rem;font-weight:500}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:3rem 0}
.ci-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.ci-icon{width:48px;height:48px;background:rgba(108,99,255,.1);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--pri);flex-shrink:0;font-size:1.25rem}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.anim.visible{opacity:1;transform:translateY(0)}

/* Related posts */
.related-posts{margin-top:3rem}.related-posts h3{margin-bottom:1.5rem}

/* Alerts */
.alert{padding:1rem 1.25rem;border-radius:var(--r-md);margin-bottom:1rem;font-size:.9375rem}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#065f46}
.alert-info{background:rgba(108,99,255,.1);border:1px solid rgba(108,99,255,.25);color:var(--sec)}

/* WC notices */
.woocommerce-message{background:rgba(16,185,129,.1);border-left:4px solid var(--grn);padding:1rem 1.25rem;border-radius:var(--r-md);margin:1rem 0}
.woocommerce-info{background:rgba(108,99,255,.1);border-left:4px solid var(--pri);padding:1rem 1.25rem;border-radius:var(--r-md);margin:1rem 0}
.woocommerce-error{background:rgba(255,107,107,.1);border-left:4px solid var(--acc);padding:1rem 1.25rem;border-radius:var(--r-md);margin:1rem 0}

/* Responsive */
@media(max-width:1024px){
  .products-grid,.cat-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .sprod-wrap{grid-template-columns:1fr;gap:2rem}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-visual{display:none}
  .hero-ctas{justify-content:center}
  .hero-stats{justify-content:center}
}
@media(max-width:768px){
  :root{--hh:60px}
  .header-search{display:none}
  .site-nav{display:none}
  .mobile-menu-toggle{display:flex}
  .products-grid,.cat-grid,.blog-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .single-wrap{grid-template-columns:1fr}
  .sidebar{display:none}
  .woo-wrap{grid-template-columns:1fr}
  .woo-sidebar{display:none}
  .cart-wrap{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .promo-banner{grid-template-columns:1fr;text-align:center}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-inner{flex-direction:column;text-align:center}
  .nl-form{flex-direction:column}
  .section-pad{padding:48px 0}
  .hero{padding:48px 0 60px}
}
@media(max-width:480px){
  .products-grid,.cat-grid,.blog-grid,.testi-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .feat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
}
