/* =====================================================
   KOKORO COFFEE - Extra PHP Component Styles
   ===================================================== */

/* ── Global Helpers ─────────────────────────────────── */
.section { padding: 80px 0; }
.section-header { text-align:center; margin-bottom:50px; position:relative; }
.section-tag { display:inline-block; font-size:0.82rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--primary); background:rgba(200,134,10,0.1); padding:5px 16px; border-radius:50px; margin-bottom:12px; }
.section-title { font-size:2.1rem; font-weight:700; color:var(--secondary); margin-bottom:14px; line-height:1.25; }
.section-link { position:absolute; right:0; top:50%; transform:translateY(-50%); font-size:0.88rem; color:var(--primary); font-weight:600; display:inline-flex; align-items:center; gap:6px; }
.section-link:hover { gap:10px; }
.section-header-light .section-title { color:#fff; }
.section-header-light .section-link { color:var(--accent); }
.bg-dark { background: var(--dark); }
.bg-light { background: var(--light-bg); }
.text-accent { color:var(--primary-light); }
.btn-outline-white { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border:2px solid rgba(255,255,255,0.6); color:#fff; border-radius:50px; font-size:0.95rem; font-weight:600; transition:all 0.3s; }
.btn-outline-white:hover { background:rgba(255,255,255,0.15); border-color:#fff; }
.btn-light { display:inline-flex; align-items:center; gap:8px; padding:11px 24px; background:#fff; color:var(--secondary); border-radius:50px; font-weight:600; font-size:0.9rem; transition:all 0.3s; }
.btn-light:hover { background:var(--off-white); }
.w-full { width:100%; justify-content:center; }
.empty-state { text-align:center; padding:60px 20px; color:var(--text-muted); }
.empty-state i { font-size:3rem; display:block; margin-bottom:16px; opacity:0.4; }
.empty-state h3 { font-size:1.2rem; margin-bottom:8px; color:var(--text-light); }
.empty-state a { color:var(--primary); font-weight:600; }

/* ── Preloader ──────────────────────────────────────── */
#preloader { position:fixed; inset:0; background:var(--dark); z-index:9999; display:flex; align-items:center; justify-content:center; transition:opacity 0.5s; }
#preloader.hidden { opacity:0; pointer-events:none; }
.preloader-inner { text-align:center; color:rgba(255,255,255,0.6); font-size:0.9rem; }
.coffee-cup { margin-bottom:20px; }
.cup-body { width:50px; height:40px; background:var(--primary); border-radius:0 0 12px 12px; margin:0 auto; position:relative; }
.steam { display:flex; gap:6px; justify-content:center; margin-bottom:8px; }
.steam span { width:4px; height:20px; background:rgba(200,134,10,0.6); border-radius:2px; animation:steam 1.5s ease-in-out infinite; }
.steam span:nth-child(2) { animation-delay:0.3s; }
.steam span:nth-child(3) { animation-delay:0.6s; }
@keyframes steam { 0%,100%{transform:scaleY(0.5);opacity:0.3;} 50%{transform:scaleY(1);opacity:1;} }

/* ── Top Bar ────────────────────────────────────────── */
.top-bar { background:var(--secondary); color:rgba(255,255,255,0.7); font-size:0.82rem; padding:8px 0; }
.top-bar-inner { display:flex; justify-content:space-between; align-items:center; }
.top-bar-left { display:flex; gap:20px; align-items:center; }
.top-bar-left span { display:flex; align-items:center; gap:6px; }
.top-bar-right { display:flex; gap:12px; }
.top-bar-right a { color:rgba(255,255,255,0.6); font-size:0.85rem; transition:color 0.2s; }
.top-bar-right a:hover { color:#fff; }

/* ── Header ─────────────────────────────────────────── */
.header { background:#fff; box-shadow:0 2px 20px rgba(44,26,14,0.08); position:sticky; top:0; z-index:800; padding:0; transition:all 0.3s; }
.header-inner { display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:20px; }
.logo a { display:flex; align-items:center; gap:12px; }
.logo-icon { width:44px; height:44px; background:linear-gradient(135deg,var(--primary),var(--primary-dark)); border-radius:10px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.2rem; flex-shrink:0; }
.logo-text { display:flex; flex-direction:column; }
.logo-main { font-size:1.1rem; font-weight:700; color:var(--secondary); line-height:1; }
.logo-sub { font-size:0.7rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }
.main-nav .nav-list { display:flex; gap:4px; align-items:center; }
.main-nav .nav-item > a { display:inline-flex; align-items:center; gap:5px; padding:10px 14px; color:var(--text); font-weight:500; font-size:0.9rem; border-radius:8px; transition:all 0.2s; }
.main-nav .nav-item > a:hover, .main-nav .nav-item.active > a { color:var(--primary); background:rgba(200,134,10,0.07); }
.main-nav .has-dropdown { position:relative; }
.main-nav .dropdown-menu { position:absolute; top:calc(100% + 8px); left:0; background:#fff; border-radius:12px; box-shadow:0 10px 40px rgba(44,26,14,0.18); padding:10px; min-width:200px; opacity:0; visibility:hidden; transform:translateY(-8px); transition:all 0.25s; z-index:900; list-style:none; }
.main-nav .has-dropdown:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.main-nav .dropdown-menu li a { display:block; padding:9px 14px; border-radius:8px; color:var(--text); font-size:0.88rem; transition:all 0.2s; }
.main-nav .dropdown-menu li a:hover { background:var(--light-bg); color:var(--primary); }
.header-actions { display:flex; align-items:center; gap:6px; }
.header-btn { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--text-light); font-size:1rem; transition:all 0.2s; position:relative; cursor:pointer; }
.header-btn:hover { background:var(--light-bg); color:var(--primary); }
.cart-count { position:absolute; top:-3px; right:-3px; width:18px; height:18px; background:var(--primary); color:#fff; font-size:0.62rem; font-weight:700; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.nav-toggle { display:none; flex-direction:column; gap:5px; width:38px; height:38px; align-items:center; justify-content:center; border-radius:8px; background:var(--light-bg); }
.nav-toggle span { display:block; width:20px; height:2px; background:var(--secondary); border-radius:2px; transition:all 0.3s; }

/* ── Search Overlay ─────────────────────────────────── */
.search-overlay { position:fixed; inset:0; background:rgba(26,15,7,0.95); z-index:1000; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:all 0.3s; }
.search-overlay.active { opacity:1; visibility:visible; }
.search-overlay-inner { width:100%; max-width:600px; padding:20px; position:relative; }
.search-form { display:flex; background:#fff; border-radius:50px; overflow:hidden; }
.search-form input { flex:1; padding:16px 24px; border:none; font-size:1rem; color:var(--text); background:transparent; }
.search-form button { padding:16px 24px; background:var(--primary); color:#fff; border:none; cursor:pointer; font-size:1rem; }
.search-close { position:absolute; top:-50px; right:0; width:40px; height:40px; background:rgba(255,255,255,0.1); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.2rem; cursor:pointer; }

/* ── Cart Sidebar ───────────────────────────────────── */
.cart-sidebar { position:fixed; top:0; right:-420px; width:400px; max-width:95vw; height:100vh; background:#fff; z-index:1001; display:flex; flex-direction:column; box-shadow:-4px 0 30px rgba(44,26,14,0.2); transition:right 0.35s cubic-bezier(0.4,0,0.2,1); }
.cart-sidebar.open { right:0; }
.cart-sidebar-header { display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--border); flex-shrink:0; }
.cart-sidebar-header h3 { font-size:1rem; font-weight:700; color:var(--secondary); display:flex; align-items:center; gap:8px; }
.cart-close { width:32px; height:32px; border-radius:50%; background:var(--light-bg); display:flex; align-items:center; justify-content:center; color:var(--text-light); font-size:0.85rem; cursor:pointer; }
.cart-sidebar-body { flex:1; overflow-y:auto; padding:16px 22px; }
.cart-item { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); }
.cart-item-img img { width:60px; height:60px; border-radius:8px; object-fit:cover; }
.no-img { width:60px; height:60px; border-radius:8px; background:var(--light-bg); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:1.4rem; }
.cart-item-info { flex:1; }
.cart-item-name { font-size:0.88rem; font-weight:600; color:var(--secondary); }
.cart-item-price { font-size:0.85rem; color:var(--primary); font-weight:600; margin-top:4px; }
.cart-item-qty { display:flex; align-items:center; gap:8px; margin-top:6px; }
.cart-item-qty button { width:24px; height:24px; border-radius:6px; background:var(--light-bg); font-size:0.85rem; font-weight:700; color:var(--text); cursor:pointer; }
.cart-item-remove { color:var(--text-muted); font-size:0.85rem; cursor:pointer; padding:4px; transition:color 0.2s; align-self:flex-start; }
.cart-item-remove:hover { color:#e74c3c; }
.cart-empty { text-align:center; padding:40px 20px; color:var(--text-muted); }
.cart-empty i { font-size:3rem; display:block; margin-bottom:12px; opacity:0.4; }
.cart-empty p { margin-bottom:16px; }
.cart-sidebar-footer { padding:18px 22px; border-top:1px solid var(--border); flex-shrink:0; }
.cart-subtotal { display:flex; justify-content:space-between; align-items:center; font-size:0.88rem; color:var(--text-light); margin-bottom:12px; }
.cart-total-price { font-weight:700; color:var(--primary); font-size:1rem; }
.overlay-backdrop { position:fixed; inset:0; background:rgba(26,15,7,0.6); z-index:1000; opacity:0; visibility:hidden; transition:all 0.3s; }
.overlay-backdrop.active { opacity:1; visibility:visible; }

/* ── Buttons ─────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:11px 26px; border-radius:50px; font-weight:600; font-size:0.9rem; transition:all 0.3s; cursor:pointer; border:none; }
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-dark); transform:translateY(-1px); box-shadow:0 6px 20px rgba(200,134,10,0.35); }
.btn-secondary { background:var(--light-bg); color:var(--text); }
.btn-secondary:hover { background:var(--border); }
.btn-outline { background:transparent; color:var(--primary); border:2px solid var(--primary); }
.btn-outline:hover { background:var(--primary); color:#fff; }
.btn-lg { padding:14px 32px; font-size:1rem; }
.btn-sm { padding:8px 16px; font-size:0.82rem; }
.btn-block { width:100%; justify-content:center; }
.btn + .btn { margin-top:8px; }

/* ── Page Banner ─────────────────────────────────────── */
.page-banner { background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-light,#3d2512) 100%); padding:50px 0; }
.page-banner-content { text-align:center; }
.page-banner h1 { color:#fff; font-size:2rem; font-weight:700; margin-bottom:14px; }
.page-breadcrumb { display:inline-flex; align-items:center; gap:8px; font-size:0.85rem; color:rgba(255,255,255,0.55); }
.page-breadcrumb a { color:rgba(255,255,255,0.55); }
.page-breadcrumb a:hover { color:#fff; }
.page-breadcrumb i { font-size:0.65rem; }
.page-breadcrumb span { color:rgba(255,255,255,0.85); }

/* ── Hero Section ────────────────────────────────────── */
.hero-section { overflow:hidden; }
.hero-slide { min-height:92vh; display:flex; align-items:center; }
.hero-slide .container { display:flex; align-items:center; justify-content:space-between; gap:40px; padding:60px 20px; }
.hero-content { flex:1; max-width:600px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(200,134,10,0.15); border:1px solid rgba(200,134,10,0.3); color:var(--primary-light,#e8a82a); padding:7px 18px; border-radius:50px; font-size:0.85rem; font-weight:600; margin-bottom:22px; }
.hero-title { font-size:3.4rem; font-weight:700; color:#fff; line-height:1.15; margin-bottom:20px; }
.hero-subtitle { font-size:1.05rem; color:rgba(255,255,255,0.7); line-height:1.8; margin-bottom:32px; max-width:500px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px; }
.hero-stats { display:flex; align-items:center; gap:24px; }
.hero-stat { text-align:center; }
.stat-num { display:block; font-size:1.6rem; font-weight:700; color:#fff; }
.stat-label { display:block; font-size:0.75rem; color:rgba(255,255,255,0.55); margin-top:2px; }
.stat-divider { width:1px; height:36px; background:rgba(255,255,255,0.15); }
.hero-image { flex:0 0 400px; position:relative; display:flex; align-items:center; justify-content:center; }
.hero-img-circle { width:320px; height:320px; background:rgba(255,255,255,0.06); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:6rem; color:rgba(255,255,255,0.15); border:2px solid rgba(255,255,255,0.08); }
.floating-badge { position:absolute; background:#fff; border-radius:12px; padding:10px 16px; font-size:0.82rem; font-weight:600; color:var(--secondary); box-shadow:0 8px 25px rgba(0,0,0,0.2); display:flex; align-items:center; gap:8px; white-space:nowrap; }
.floating-badge i { color:var(--primary); }
.badge-1 { top:20%; left:-10px; }
.badge-2 { top:50%; right:-10px; }
.badge-3 { bottom:20%; left:0; }

/* ── Features Bar ────────────────────────────────────── */
.features-bar { background:var(--secondary); padding:28px 0; }
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.feature-item { display:flex; align-items:center; gap:14px; }
.feature-icon { width:44px; height:44px; background:rgba(200,134,10,0.15); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.1rem; flex-shrink:0; }
.feature-text h4 { color:#fff; font-size:0.9rem; font-weight:600; margin-bottom:2px; }
.feature-text p { color:rgba(255,255,255,0.5); font-size:0.78rem; }

/* ── Categories ──────────────────────────────────────── */
.categories-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.category-card { display:flex; align-items:center; gap:14px; background:#fff; border:1px solid var(--border); border-radius:14px; padding:18px 20px; transition:all 0.3s; text-decoration:none; }
.category-card:hover { border-color:var(--primary); box-shadow:0 6px 24px rgba(200,134,10,0.12); transform:translateY(-2px); }
.category-icon { width:48px; height:48px; background:rgba(200,134,10,0.1); border-radius:12px; display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.2rem; flex-shrink:0; }
.category-info h3 { font-size:0.95rem; font-weight:600; color:var(--secondary); }
.category-info span { font-size:0.78rem; color:var(--text-muted); }
.category-arrow { margin-left:auto; color:var(--text-muted); font-size:0.85rem; transition:transform 0.2s; }
.category-card:hover .category-arrow { color:var(--primary); transform:translateX(4px); }

/* ── Products Grid ───────────────────────────────────── */
.products-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.products-grid.grid-4 { grid-template-columns:repeat(4,1fr); }
.product-card { background:#fff; border-radius:16px; overflow:hidden; border:1px solid var(--border); transition:all 0.3s; position:relative; }
.product-card:hover { box-shadow:0 12px 40px rgba(44,26,14,0.14); transform:translateY(-4px); }
.product-badge { position:absolute; top:12px; left:12px; z-index:2; font-size:0.72rem; font-weight:700; padding:4px 12px; border-radius:50px; }
.badge-sale { background:#e74c3c; color:#fff; }
.badge-featured { background:var(--primary); color:#fff; }
.badge-new { background:#27ae60; color:#fff; }
.badge-lg { top:16px; left:16px; font-size:0.85rem; padding:6px 16px; }
.product-img-wrap { display:block; position:relative; overflow:hidden; aspect-ratio:1; background:var(--light-bg); }
.product-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.product-card:hover .product-img-wrap img { transform:scale(1.06); }
.product-img-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; color:var(--border); }
.product-img-placeholder-lg { width:100%; aspect-ratio:1; background:var(--light-bg); display:flex; align-items:center; justify-content:center; font-size:6rem; color:var(--border); border-radius:14px; }
.product-overlay { position:absolute; inset:0; background:rgba(26,15,7,0.55); display:flex; align-items:center; justify-content:center; gap:8px; opacity:0; transition:opacity 0.3s; }
.product-card:hover .product-overlay { opacity:1; }
.product-info { padding:16px; }
.product-cat { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--primary); }
.product-name { margin:6px 0; }
.product-name a { font-size:0.95rem; font-weight:600; color:var(--secondary); transition:color 0.2s; }
.product-name a:hover { color:var(--primary); }
.product-origin { font-size:0.78rem; color:var(--text-muted); display:flex; align-items:center; gap:4px; margin-bottom:8px; }
.product-price { display:flex; align-items:center; gap:8px; margin-top:8px; }
.price-current { font-weight:700; font-size:1.05rem; color:var(--primary); }
.price-old { font-size:0.85rem; color:var(--text-muted); text-decoration:line-through; }
.product-stock { font-size:0.75rem; margin-top:6px; display:flex; align-items:center; gap:4px; }
.product-stock.out { color:#e74c3c; }
.product-stock.low { color:#f39c12; }

/* ── Promo Banner ────────────────────────────────────── */
.promo-banner { padding:40px 0; }
.promo-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.promo-card { border-radius:16px; padding:44px 40px; overflow:hidden; position:relative; }
.promo-primary { background:linear-gradient(135deg,#8B4513,#6B3410); }
.promo-dark { background:linear-gradient(135deg,var(--secondary),var(--dark)); }
.promo-tag { display:inline-block; font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--primary-light,#e8a82a); margin-bottom:12px; }
.promo-card h3 { font-size:1.7rem; font-weight:700; color:#fff; line-height:1.3; margin-bottom:12px; }
.promo-card p { color:rgba(255,255,255,0.65); font-size:0.9rem; margin-bottom:22px; }

/* ── Why Section ─────────────────────────────────────── */
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.why-card { text-align:center; padding:32px 20px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.07); border-radius:16px; transition:all 0.3s; }
.why-card:hover { background:rgba(255,255,255,0.07); border-color:rgba(200,134,10,0.3); }
.why-icon { width:60px; height:60px; background:rgba(200,134,10,0.15); border-radius:14px; display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.4rem; margin:0 auto 18px; }
.why-card h3 { color:#fff; font-size:1rem; font-weight:600; margin-bottom:10px; }
.why-card p { color:rgba(255,255,255,0.55); font-size:0.88rem; line-height:1.7; }

/* ── Testimonials ────────────────────────────────────── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card { background:#fff; border-radius:16px; padding:28px; border:1px solid var(--border); transition:box-shadow 0.3s; }
.testimonial-card:hover { box-shadow:var(--shadow); }
.testimonial-stars { color:#f39c12; font-size:0.9rem; margin-bottom:14px; display:flex; gap:3px; }
.testimonial-text { color:var(--text-light); font-size:0.92rem; line-height:1.8; margin-bottom:18px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.author-avatar { width:40px; height:40px; background:linear-gradient(135deg,var(--primary),var(--primary-dark)); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; flex-shrink:0; }
.author-name { font-size:0.88rem; font-weight:600; color:var(--secondary); }
.author-product { font-size:0.75rem; color:var(--text-muted); }

/* ── Newsletter ──────────────────────────────────────── */
.newsletter-section { background:var(--primary); padding:50px 0; }
.newsletter-inner { display:flex; align-items:center; justify-content:space-between; gap:40px; }
.newsletter-text h3 { color:#fff; font-size:1.5rem; font-weight:700; margin-bottom:6px; }
.newsletter-text p { color:rgba(255,255,255,0.75); font-size:0.9rem; }
.newsletter-form { display:flex; gap:10px; flex:0 0 480px; }
.newsletter-form input { flex:1; padding:13px 20px; border-radius:50px; border:none; font-size:0.9rem; background:rgba(255,255,255,0.92); }
.newsletter-form input:focus { background:#fff; outline:none; }
.newsletter-form .btn-primary { background:var(--secondary); flex-shrink:0; }
.newsletter-form .btn-primary:hover { background:var(--dark); }

/* ── Footer ──────────────────────────────────────────── */
.footer { background:var(--dark); }
.footer-top { padding:70px 0 40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; }
.footer-brand .footer-logo { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer-logo .logo-icon { width:40px; height:40px; background:var(--primary); border-radius:10px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1rem; }
.footer-logo .logo-main { color:#fff; font-size:1rem; font-weight:700; }
.footer-desc { color:rgba(255,255,255,0.45); font-size:0.88rem; line-height:1.8; margin-bottom:20px; }
.footer-social { display:flex; gap:8px; }
.footer-social a { width:36px; height:36px; background:rgba(255,255,255,0.07); border-radius:8px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.5); font-size:0.88rem; transition:all 0.2s; }
.footer-social a:hover { background:var(--primary); color:#fff; }
.footer-title { font-size:0.82rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.4); margin-bottom:18px; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:10px; }
.footer-links a { color:rgba(255,255,255,0.5); font-size:0.88rem; transition:color 0.2s; }
.footer-links a:hover { color:#fff; }
.footer-contact { list-style:none; }
.footer-contact li { display:flex; gap:12px; margin-bottom:12px; color:rgba(255,255,255,0.5); font-size:0.88rem; }
.footer-contact i { color:var(--primary); width:14px; margin-top:3px; flex-shrink:0; }
.footer-contact a { color:rgba(255,255,255,0.5); }
.footer-contact a:hover { color:#fff; }
.footer-bottom { padding:20px 0; border-top:1px solid rgba(255,255,255,0.06); }
.footer-bottom-inner { display:flex; justify-content:space-between; align-items:center; }
.footer-bottom p { color:rgba(255,255,255,0.3); font-size:0.82rem; }
.payment-icons { display:flex; gap:10px; font-size:1.3rem; color:rgba(255,255,255,0.3); }
.back-to-top { position:fixed; bottom:30px; right:30px; width:44px; height:44px; background:var(--primary); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; visibility:hidden; transition:all 0.3s; z-index:500; box-shadow:0 4px 16px rgba(200,134,10,0.4); }
.back-to-top.show { opacity:1; visibility:visible; }
.back-to-top:hover { background:var(--primary-dark); transform:translateY(-2px); }
.toast-container { position:fixed; bottom:30px; left:50%; transform:translateX(-50%); z-index:9999; display:flex; flex-direction:column; gap:10px; pointer-events:none; }
.toast { background:#fff; border-radius:10px; padding:12px 20px; box-shadow:0 6px 24px rgba(44,26,14,0.18); font-size:0.9rem; font-weight:500; display:flex; align-items:center; gap:10px; pointer-events:auto; }
.toast-success { border-left:4px solid #27ae60; }
.toast-error { border-left:4px solid #e74c3c; }
.toast-warning { border-left:4px solid #f39c12; }

/* ── Shop Page ───────────────────────────────────────── */
.shop-section { padding:60px 0; }
.shop-layout { display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:start; }
.shop-sidebar { background:#fff; border-radius:14px; border:1px solid var(--border); padding:24px; position:sticky; top:100px; }
.sidebar-widget { margin-bottom:28px; }
.sidebar-widget:last-child { margin-bottom:0; }
.widget-title { font-size:0.82rem; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-light); margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.sidebar-search { display:flex; gap:0; }
.sidebar-search input { flex:1; padding:9px 14px; border:1.5px solid var(--border); border-right:none; border-radius:8px 0 0 8px; font-size:0.88rem; }
.sidebar-search button { padding:9px 14px; background:var(--primary); color:#fff; border:none; border-radius:0 8px 8px 0; cursor:pointer; }
.cat-list, .filter-list { list-style:none; }
.cat-list li, .filter-list li { margin-bottom:4px; }
.cat-list a, .filter-list a { display:flex; justify-content:space-between; align-items:center; padding:8px 12px; border-radius:8px; color:var(--text-light); font-size:0.88rem; transition:all 0.2s; }
.cat-list a:hover, .cat-list li.active a { background:var(--light-bg); color:var(--primary); }
.cat-count { background:var(--light-bg); color:var(--text-muted); font-size:0.72rem; padding:2px 8px; border-radius:12px; }
.cat-list li.active .cat-count { background:rgba(200,134,10,0.15); color:var(--primary); }
.shop-toolbar { display:flex; justify-content:space-between; align-items:center; padding:14px 18px; background:#fff; border-radius:10px; border:1px solid var(--border); margin-bottom:24px; }
.shop-count { font-size:0.88rem; color:var(--text-light); }
.shop-sort { display:flex; align-items:center; gap:10px; font-size:0.88rem; color:var(--text-light); }
.shop-sort select { padding:7px 12px; border:1.5px solid var(--border); border-radius:8px; font-size:0.85rem; color:var(--text); background:#fff; }
.pagination-wrap { display:flex; justify-content:center; gap:6px; margin-top:40px; flex-wrap:wrap; }
.page-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:8px; border:1.5px solid var(--border); color:var(--text-light); font-size:0.88rem; transition:all 0.2s; text-decoration:none; }
.page-btn:hover { border-color:var(--primary); color:var(--primary); }
.page-btn.active { background:var(--primary); color:#fff; border-color:var(--primary); font-weight:700; }

/* ── Product Detail ──────────────────────────────────── */
.product-detail-section { padding:60px 0; }
.product-detail-layout { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; margin-bottom:60px; }
.main-img-wrap { position:relative; border-radius:16px; overflow:hidden; background:var(--light-bg); aspect-ratio:1; }
.main-img-wrap img { width:100%; height:100%; object-fit:cover; }
.product-detail-cat { font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--primary); margin-bottom:10px; display:block; text-decoration:none; }
.product-detail-title { font-size:1.9rem; font-weight:700; color:var(--secondary); line-height:1.25; margin-bottom:6px; }
.product-detail-title-th { font-size:1rem; color:var(--text-light); margin-bottom:18px; }
.product-detail-price { display:flex; align-items:center; gap:12px; margin-bottom:18px; flex-wrap:wrap; }
.price-main { font-size:2rem; font-weight:700; color:var(--primary); }
.price-original { font-size:1.1rem; color:var(--text-muted); text-decoration:line-through; }
.price-save { background:rgba(231,76,60,0.1); color:#e74c3c; font-size:0.82rem; font-weight:700; padding:3px 10px; border-radius:50px; }
.product-detail-short { color:var(--text-light); font-size:0.95rem; line-height:1.8; margin-bottom:22px; }
.product-specs { display:grid; grid-template-columns:1fr 1fr; gap:10px; background:var(--light-bg); border-radius:12px; padding:16px; margin-bottom:18px; }
.spec-item { display:flex; flex-direction:column; gap:3px; }
.spec-label { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); display:flex; align-items:center; gap:5px; }
.spec-value { font-size:0.9rem; font-weight:600; color:var(--secondary); }
.product-stock-status { margin-bottom:18px; }
.stock-in { color:#27ae60; font-size:0.88rem; font-weight:600; display:flex; align-items:center; gap:6px; }
.stock-out { color:#e74c3c; font-size:0.88rem; font-weight:600; display:flex; align-items:center; gap:6px; }
.product-add-cart { display:flex; gap:12px; align-items:center; margin-bottom:12px; flex-wrap:wrap; }
.qty-control { display:flex; align-items:center; gap:0; border:1.5px solid var(--border); border-radius:10px; overflow:hidden; }
.qty-btn { width:38px; height:44px; background:var(--light-bg); color:var(--text); font-size:1.1rem; font-weight:700; cursor:pointer; border:none; transition:background 0.2s; display:flex; align-items:center; justify-content:center; }
.qty-btn:hover { background:var(--border); }
.qty-input, .qty-control input[type="number"] { width:50px; height:44px; text-align:center; border:none; font-size:0.95rem; font-weight:700; color:var(--secondary); background:#fff; -moz-appearance:textfield; }
.qty-control input[type="number"]::-webkit-outer-spin-button,
.qty-control input[type="number"]::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.product-tags { display:flex; gap:6px; flex-wrap:wrap; margin:14px 0; }
.tag { display:inline-block; padding:4px 12px; background:var(--light-bg); border-radius:50px; font-size:0.78rem; color:var(--text-light); transition:all 0.2s; }
.tag:hover { background:rgba(200,134,10,0.1); color:var(--primary); }
.product-share { display:flex; align-items:center; gap:10px; margin-top:16px; font-size:0.88rem; color:var(--text-light); }
.share-btn { width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:0.85rem; transition:all 0.2s; }
.share-btn.facebook { background:#1877f2; }
.share-btn.line { background:#06c755; }
.share-btn:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,0.2); }
.product-tabs { background:#fff; border-radius:16px; border:1px solid var(--border); overflow:hidden; }
.tabs-header { display:flex; border-bottom:1px solid var(--border); }
.tab-btn { padding:16px 28px; font-size:0.9rem; font-weight:600; color:var(--text-light); cursor:pointer; border-bottom:3px solid transparent; transition:all 0.2s; background:transparent; border-top:none; border-left:none; border-right:none; }
.tab-btn:hover { color:var(--primary); }
.tab-btn.active { color:var(--primary); border-bottom-color:var(--primary); }
.tab-content { display:none; padding:28px; }
.tab-content.active { display:block; }
.product-description { color:var(--text); line-height:1.9; font-size:0.95rem; }
.shipping-info { list-style:none; padding:0; }
.shipping-info li { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--border-light,#f0e8e0); color:var(--text-light); font-size:0.92rem; }
.shipping-info i { color:var(--primary); width:16px; margin-top:3px; flex-shrink:0; }

/* ── Cart ────────────────────────────────────────────── */
.cart-section { padding:60px 0; }
.cart-empty-page { text-align:center; padding:80px 20px; }
.cart-empty-page i { font-size:4rem; color:var(--border); display:block; margin-bottom:20px; }
.cart-empty-page h2 { font-size:1.5rem; color:var(--secondary); margin-bottom:10px; }
.cart-empty-page p { color:var(--text-muted); margin-bottom:24px; }
.cart-layout { display:grid; grid-template-columns:1fr 380px; gap:40px; align-items:start; }
.cart-items-wrap { background:#fff; border-radius:16px; border:1px solid var(--border); overflow:hidden; }
.cart-table-header { display:grid; grid-template-columns:1fr 100px 130px 100px 40px; gap:16px; padding:14px 20px; background:var(--light-bg); font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); }
.cart-row { display:grid; grid-template-columns:1fr 100px 130px 100px 40px; gap:16px; align-items:center; padding:16px 20px; border-bottom:1px solid var(--border-light,#f0e8e0); }
.cart-row:last-child { border-bottom:none; }
.col-product { display:flex; align-items:center; gap:14px; }
.cart-product-img img { width:64px; height:64px; border-radius:10px; object-fit:cover; }
.cart-no-img { width:64px; height:64px; border-radius:10px; background:var(--light-bg); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:1.4rem; }
.cart-product-name { font-size:0.9rem; font-weight:600; color:var(--secondary); }
.cart-product-price-mobile { display:none; font-size:0.85rem; color:var(--primary); font-weight:600; margin-top:3px; }
.col-price, .col-total { font-size:0.92rem; font-weight:600; color:var(--text); }
.item-subtotal { color:var(--primary); }
.cart-qty-minus, .cart-qty-plus { width:28px; height:28px; border-radius:6px; background:var(--light-bg); color:var(--text); font-size:0.95rem; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background 0.2s; }
.cart-qty-minus:hover, .cart-qty-plus:hover { background:var(--border); }
.cart-remove-btn { color:var(--text-muted); cursor:pointer; font-size:0.9rem; transition:color 0.2s; }
.cart-remove-btn:hover { color:#e74c3c; }
.cart-coupon { display:flex; justify-content:space-between; align-items:center; padding:16px 20px; background:var(--light-bg); gap:16px; flex-wrap:wrap; }
.coupon-form { display:flex; gap:8px; }
.coupon-form input { padding:9px 16px; border:1.5px solid var(--border); border-radius:8px; font-size:0.88rem; background:#fff; min-width:180px; }
.cart-summary { background:#fff; border-radius:16px; border:1px solid var(--border); padding:24px; position:sticky; top:100px; }
.summary-title { font-size:1.05rem; font-weight:700; color:var(--secondary); margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--border); }
.summary-row { display:flex; justify-content:space-between; align-items:center; padding:10px 0; font-size:0.9rem; color:var(--text-light); border-bottom:1px solid var(--border-light,#f0e8e0); }
.summary-total { display:flex; justify-content:space-between; align-items:center; padding:16px 0 16px; margin-top:6px; font-weight:700; font-size:1.05rem; color:var(--secondary); border-top:2px solid var(--border); }
.free-shipping-progress { padding:12px 0; }
.free-shipping-progress p { font-size:0.82rem; color:var(--text-light); margin-bottom:8px; }
.free-shipping-progress strong { color:var(--primary); }
.progress-bar { height:6px; background:var(--border); border-radius:50px; overflow:hidden; }
.progress-fill { height:100%; background:var(--primary); border-radius:50px; transition:width 0.4s; }
.cart-security { text-align:center; font-size:0.78rem; color:var(--text-muted); margin:12px 0; display:flex; align-items:center; justify-content:center; gap:6px; }
.payment-methods-mini { display:flex; justify-content:center; gap:10px; font-size:1.6rem; color:var(--text-muted); }

/* ── About ───────────────────────────────────────────── */
.about-story { padding:80px 0; }
.about-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-circle { width:100%; aspect-ratio:1; max-width:440px; background:linear-gradient(135deg,var(--secondary),var(--dark)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:8rem; color:rgba(255,255,255,0.08); }
.about-stat-card { position:absolute; bottom:-20px; right:-20px; background:var(--primary); color:#fff; border-radius:14px; padding:18px 22px; text-align:center; box-shadow:var(--shadow-lg); }
.stat-big { display:block; font-size:1.8rem; font-weight:700; line-height:1; }
.stat-text { font-size:0.78rem; opacity:0.8; }
.about-lead { font-size:1.1rem; color:var(--secondary); font-weight:500; line-height:1.8; margin-bottom:16px; }
.about-values { display:flex; gap:20px; flex-wrap:wrap; margin:24px 0; }
.value-item { display:flex; align-items:center; gap:8px; font-size:0.88rem; font-weight:600; color:var(--primary); }
.value-item i { width:32px; height:32px; background:rgba(200,134,10,0.1); border-radius:8px; display:flex; align-items:center; justify-content:center; }
.stats-section { padding:50px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat-box { text-align:center; padding:20px; }
.stat-num-lg { display:block; font-size:2.4rem; font-weight:700; color:#fff; }
.stat-label-lg { display:block; font-size:0.88rem; color:rgba(255,255,255,0.5); margin-top:4px; }
.process-section { padding:80px 0; }
.process-steps { display:flex; align-items:flex-start; gap:0; }
.process-step { flex:1; text-align:center; padding:0 20px; }
.process-arrow { display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:1.2rem; padding-top:30px; flex-shrink:0; }
.step-num { display:inline-block; font-size:2.5rem; font-weight:700; color:var(--border); line-height:1; margin-bottom:12px; }
.step-icon { width:60px; height:60px; background:rgba(200,134,10,0.1); border-radius:14px; display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.4rem; margin:0 auto 14px; }
.process-step h3 { font-size:1rem; font-weight:700; color:var(--secondary); margin-bottom:8px; }
.process-step p { font-size:0.85rem; color:var(--text-light); line-height:1.7; }
.team-section { padding:80px 0; }
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.team-card { text-align:center; padding:36px 24px; background:#fff; border-radius:16px; border:1px solid var(--border); transition:box-shadow 0.3s; }
.team-card:hover { box-shadow:var(--shadow); }
.team-avatar { width:70px; height:70px; background:linear-gradient(135deg,var(--primary),var(--primary-dark)); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.4rem; margin:0 auto 16px; }
.team-card h3 { font-size:1rem; font-weight:700; color:var(--secondary); margin-bottom:4px; }
.team-card p { font-size:0.85rem; color:var(--text-muted); }
.cta-section { padding:80px 0; }
.cta-box { background:linear-gradient(135deg,var(--secondary),var(--dark)); border-radius:20px; padding:60px; text-align:center; }
.cta-box h2 { color:#fff; font-size:1.9rem; font-weight:700; margin-bottom:12px; }
.cta-box p { color:rgba(255,255,255,0.65); margin-bottom:30px; font-size:0.95rem; }
.cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ── Contact ──────────────────────────────────────────── */
.contact-section { padding:60px 0; }
.contact-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:50px; }
.contact-card { background:#fff; border-radius:14px; border:1px solid var(--border); padding:26px; text-align:center; transition:box-shadow 0.3s; }
.contact-card:hover { box-shadow:var(--shadow); }
.contact-card-icon { width:52px; height:52px; background:rgba(200,134,10,0.1); border-radius:12px; display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.2rem; margin:0 auto 14px; }
.contact-card h3 { font-size:0.95rem; font-weight:700; color:var(--secondary); margin-bottom:8px; }
.contact-card p { font-size:0.88rem; color:var(--text-light); }
.contact-card a { color:var(--text-light); }
.contact-card a:hover { color:var(--primary); }
.contact-layout { display:grid; grid-template-columns:1fr 380px; gap:50px; align-items:start; }
.contact-form-wrap { background:#fff; border-radius:16px; border:1px solid var(--border); padding:36px; }
.form-title { font-size:1.4rem; font-weight:700; color:var(--secondary); margin-bottom:6px; }
.form-subtitle { color:var(--text-muted); font-size:0.9rem; margin-bottom:24px; }
.contact-alert { padding:12px 18px; border-radius:10px; font-size:0.88rem; margin-bottom:18px; display:flex; align-items:center; gap:10px; }
.contact-alert.success { background:#eafaf1; color:#27ae60; border:1px solid rgba(39,174,96,0.2); }
.contact-alert.danger { background:#fdedec; color:#e74c3c; border:1px solid rgba(231,76,60,0.2); }
.contact-form .form-group { margin-bottom:16px; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.contact-form label { display:block; font-size:0.8rem; font-weight:700; text-transform:uppercase; letter-spacing:0.3px; color:var(--text-light); margin-bottom:6px; }
.contact-form label span { color:#e74c3c; }
.contact-form input, .contact-form select, .contact-form textarea { width:100%; padding:11px 16px; border:1.5px solid var(--border); border-radius:10px; font-size:0.92rem; color:var(--text); background:#faf8f5; transition:border-color 0.2s; font-family:inherit; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color:var(--primary); background:#fff; outline:none; box-shadow:0 0 0 3px rgba(200,134,10,0.1); }
.contact-form textarea { resize:vertical; line-height:1.7; }
.contact-sidebar { display:flex; flex-direction:column; gap:20px; }
.contact-info-box { background:#fff; border-radius:14px; border:1px solid var(--border); padding:22px; }
.contact-info-box h3 { font-size:0.88rem; font-weight:700; color:var(--secondary); margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.contact-info-box h3 i { color:var(--primary); }
.hours-table { width:100%; border-collapse:collapse; font-size:0.85rem; }
.hours-table td { padding:7px 0; color:var(--text-light); }
.hours-table td:last-child { text-align:right; font-weight:500; color:var(--text); }
.hours-table tr.closed td { color:var(--text-muted); }
.contact-social { display:flex; flex-direction:column; gap:8px; }
.social-link { display:flex; align-items:center; gap:10px; padding:9px 14px; border-radius:8px; font-size:0.88rem; font-weight:600; transition:all 0.2s; }
.social-link.facebook { background:#e8f0fe; color:#1877f2; }
.social-link.facebook:hover { background:#1877f2; color:#fff; }
.social-link.instagram { background:#fce4ec; color:#e1306c; }
.social-link.instagram:hover { background:#e1306c; color:#fff; }
.social-link.line { background:#e8f9ee; color:#06c755; }
.social-link.line:hover { background:#06c755; color:#fff; }
.faq-quick { list-style:none; }
.faq-quick li { display:flex; gap:8px; padding:7px 0; font-size:0.82rem; color:var(--text-light); border-bottom:1px solid var(--border-light,#f0e8e0); }
.faq-quick i { color:var(--primary); width:14px; margin-top:2px; flex-shrink:0; }

/* ── Animate ──────────────────────────────────────────── */
.animate-fade-up { animation:fadeUp 0.7s ease both; }
.animate-fade-left { animation:fadeLeft 0.7s ease both; }
.delay-1 { animation-delay:0.15s; }
.delay-2 { animation-delay:0.3s; }
.delay-3 { animation-delay:0.45s; }
.delay-4 { animation-delay:0.6s; }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:none;} }
@keyframes fadeLeft { from{opacity:0;transform:translateX(24px);} to{opacity:1;transform:none;} }

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:1200px) {
    .products-grid { grid-template-columns:repeat(3,1fr); }
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .why-grid { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr 1fr; gap:30px; }
}
@media(max-width:991px) {
    .hero-slide .container { flex-direction:column; padding:50px 20px; min-height:auto; }
    .hero-image { display:none; }
    .hero-title { font-size:2.2rem; }
    .section-title { font-size:1.7rem; }
    .main-nav { display:none; position:fixed; inset:0; top:60px; background:#fff; padding:20px; z-index:700; overflow-y:auto; }
    .main-nav.open { display:block; }
    .main-nav .nav-list { flex-direction:column; gap:4px; }
    .main-nav .nav-item > a { font-size:1rem; padding:12px 16px; }
    .main-nav .dropdown-menu { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; background:var(--light-bg); }
    .nav-toggle { display:flex; }
    .top-bar-left { gap:10px; }
    .cart-layout { grid-template-columns:1fr; }
    .cart-table-header { display:none; }
    .cart-row { grid-template-columns:1fr auto; gap:12px; }
    .col-price, .col-qty, .col-total { display:flex; align-items:center; gap:6px; }
    .cart-product-price-mobile { display:block; }
    .col-total::before { content:'ยอด: '; font-size:0.75rem; color:var(--text-muted); }
    .contact-layout { grid-template-columns:1fr; }
    .contact-cards { grid-template-columns:repeat(2,1fr); }
    .about-layout { grid-template-columns:1fr; }
    .shop-layout { grid-template-columns:1fr; }
    .shop-sidebar { position:static; }
    .categories-grid { grid-template-columns:repeat(2,1fr); }
    .product-detail-layout { grid-template-columns:1fr; }
    .newsletter-inner { flex-direction:column; text-align:center; }
    .newsletter-form { flex:none; width:100%; max-width:500px; }
    .promo-grid { grid-template-columns:1fr; }
    .process-steps { flex-direction:column; }
    .process-arrow { display:none; }
    .team-grid { grid-template-columns:repeat(2,1fr); }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .testimonials-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:767px) {
    .section { padding:50px 0; }
    .hero-title { font-size:1.8rem; }
    .hero-actions { flex-direction:column; }
    .hero-stats { gap:14px; }
    .products-grid, .products-grid.grid-4 { grid-template-columns:repeat(2,1fr); gap:14px; }
    .categories-grid { grid-template-columns:1fr 1fr; gap:12px; }
    .why-grid { grid-template-columns:1fr 1fr; }
    .top-bar-left span:nth-child(2), .top-bar-left span:nth-child(3) { display:none; }
    .testimonials-grid { grid-template-columns:1fr; }
    .form-row-2 { grid-template-columns:1fr; }
    .contact-cards { grid-template-columns:1fr 1fr; }
    .cta-box { padding:36px 20px; }
    .footer-grid { grid-template-columns:1fr; gap:24px; }
}
@media(max-width:480px) {
    .products-grid, .products-grid.grid-4 { grid-template-columns:1fr; }
    .categories-grid { grid-template-columns:1fr; }
    .contact-cards { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr 1fr; }
}