/**
 * Theme Name:  Lampaffären
 * Theme URI:   https://lampaffaren.se
 * Author:      Formatic AB
 * Author URI:  https://lampaffaren.se
 * Description: Eget WooCommerce-tema för Lampaffären (lampaffaren.se). SEO-optimerat, mobilfirst och tillgängligt. Designat och utvecklat av Formatic AB.
 * Version:     1.0.0
 * Requires at least: 6.4
 * Tested up to: 6.7
 * Requires PHP: 8.1
 * WC requires at least: 8.0
 * WC tested up to: 9.0
 * License:     Proprietary – Formatic AB
 * License URI: https://lampaffaren.se/licens
 * Text Domain: lampaffaren
 * Domain Path: /languages
 * Tags:        woocommerce, ecommerce, seo, custom, responsive
 *
 * Copyright (C) 2025 Formatic AB. Alla rättigheter förbehållna.
 * Obehörig kopiering, distribution eller modifiering av detta tema
 * är strängt förbjuden utan skriftligt tillstånd från Formatic AB.
 *
 * @package    Lampaffaren
 * @author     Formatic AB <info@lampaffaren.se>
 * @copyright  2025 Formatic AB
 * @license    Proprietary
 */

/* =========================================================
   DESIGN TOKENS
   ========================================================= */
:root {
  --c-dark:          #111827;
  --c-dark-mid:      #1F2937;
  --c-dark-soft:     #374151;
  --c-accent:        #D97706;
  --c-accent-hover:  #B45309;
  --c-accent-light:  #FDE68A;
  --c-accent-pale:   #FFFBEB;
  --c-bg:            #F9FAFB;
  --c-bg-card:       #FFFFFF;
  --c-bg-alt:        #F3F4F6;
  --c-text:          #111827;
  --c-text-muted:    #6B7280;
  --c-text-light:    #9CA3AF;
  --c-border:        #E5E7EB;
  --c-border-dark:   #D1D5DB;
  --c-success:       #065F46;
  --c-success-bg:    #D1FAE5;
  --c-error:         #991B1B;
  --c-error-bg:      #FEE2E2;
  --c-info-bg:       #EFF6FF;
  --c-info:          #1E40AF;

  --font-head:  'Playfair Display', Georgia, serif;
  --font-body:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --r-sm:  4px;
  --r-md:  8px;
  --r-lg:  12px;
  --r-xl:  16px;

  --max-w:     1240px;
  --hdr-h:     68px;
  --transition: 150ms ease;
}

/* =========================================================
   RESET
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-body); font-size: 1rem; line-height: 1.7; color: var(--c-text); background: var(--c-bg); margin: 0; }
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; }
ul, ol { padding-left: 1.5rem; }
p { margin: 0 0 1rem; }
button, input, select, textarea { font-family: var(--font-body); font-size: 1rem; }
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 2px; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-head); font-weight: 700; line-height: 1.2; margin: 0 0 0.75rem; color: var(--c-dark); }
h1 { font-size: clamp(1.75rem, 4vw, 2.75rem); }
h2 { font-size: clamp(1.375rem, 3vw, 2rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.4rem); }
h4 { font-size: 1.1rem; }

/* =========================================================
   LAYOUT
   ========================================================= */
.container { width: 100%; max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.site-main { min-height: 60vh; padding: 2rem 0 3rem; }

/* =========================================================
   SKIP LINK
   ========================================================= */
.skip-link { position: absolute; top: -200%; left: 1rem; z-index: 9999; background: var(--c-accent); color: #fff; font-weight: 600; padding: .5rem 1rem; border-radius: var(--r-md); font-size: .875rem; transition: top .15s; }
.skip-link:focus { top: 1rem; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header { background: var(--c-dark); position: sticky; top: 0; z-index: 200; border-bottom: 1px solid rgba(255,255,255,.06); }
.header-inner { display: flex; align-items: center; height: var(--hdr-h); gap: 1rem; }

.site-branding a { font-family: var(--font-head); font-size: 1.35rem; font-weight: 700; color: var(--c-accent); letter-spacing: .01em; white-space: nowrap; }
.site-branding a:hover { text-decoration: none; opacity: .85; }

.main-nav ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 2px; }
.main-nav a { display: block; padding: .5rem .875rem; font-size: .875rem; font-weight: 500; color: rgba(255,255,255,.75); border-radius: var(--r-sm); transition: background var(--transition), color var(--transition); }
.main-nav a:hover, .main-nav .current-menu-item > a { background: rgba(255,255,255,.08); color: var(--c-accent); text-decoration: none; }
.main-nav li { position: relative; }
.main-nav ul ul { position: absolute; top: 100%; left: 0; background: var(--c-dark-mid); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-lg); padding: .5rem; min-width: 200px; display: none; flex-direction: column; z-index: 100; }
.main-nav li:focus-within > ul, .main-nav li:hover > ul { display: flex; }
.main-nav ul ul a { white-space: nowrap; color: rgba(255,255,255,.7); }

.header-actions { display: flex; align-items: center; gap: .5rem; margin-left: auto; }

.header-search-form { display: flex; align-items: center; }
.header-search-form input[type="search"] { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 20px; padding: .4rem 1rem; color: #fff; font-size: .8125rem; width: 160px; transition: width var(--transition), background var(--transition); }
.header-search-form input[type="search"]:focus { width: 220px; background: rgba(255,255,255,.13); outline: none; border-color: var(--c-accent); }
.header-search-form input[type="search"]::placeholder { color: rgba(255,255,255,.4); }
.header-search-form button { display: none; }

.cart-btn { display: flex; align-items: center; gap: .4rem; color: rgba(255,255,255,.8); font-size: .8125rem; font-weight: 500; padding: .5rem .75rem; border-radius: var(--r-sm); transition: background var(--transition); white-space: nowrap; }
.cart-btn:hover { background: rgba(255,255,255,.08); color: var(--c-accent); text-decoration: none; }
.cart-btn svg { width: 18px; height: 18px; flex-shrink: 0; }
.cart-count { background: var(--c-accent); color: #fff; font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; line-height: 1; }

.menu-toggle { display: none; background: transparent; border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.8); border-radius: var(--r-sm); padding: .4rem .75rem; cursor: pointer; font-size: .875rem; }

@media (max-width: 900px) {
  .main-nav { display: none; }
  .menu-toggle { display: block; }
  .main-nav.is-open { display: block; position: absolute; top: var(--hdr-h); left: 0; right: 0; background: var(--c-dark-mid); border-top: 1px solid rgba(255,255,255,.06); padding: 1rem 1.5rem 1.5rem; }
  .main-nav.is-open ul { flex-direction: column; gap: 2px; }
  .main-nav.is-open ul ul { position: static; display: flex; box-shadow: none; background: rgba(255,255,255,.04); margin: 4px 0 4px 1rem; border: none; }
  .header-search-form input[type="search"] { width: 120px; }
}

/* =========================================================
   BREADCRUMBS
   ========================================================= */
.breadcrumb-wrap { padding: .75rem 0 1.25rem; font-size: .8125rem; color: var(--c-text-muted); }
.breadcrumb-wrap a { color: var(--c-accent-hover); }
.breadcrumb-wrap a:hover { text-decoration: underline; }
.breadcrumb-sep { margin: 0 .35rem; opacity: .4; }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .75rem 1.5rem; border-radius: var(--r-md); font-weight: 600; font-size: .875rem; cursor: pointer; border: 2px solid transparent; transition: all var(--transition); text-decoration: none !important; white-space: nowrap; line-height: 1; }
.btn-primary { background: var(--c-dark); color: #fff; border-color: var(--c-dark); }
.btn-primary:hover { background: var(--c-dark-mid); }
.btn-accent { background: var(--c-accent); color: #fff; border-color: var(--c-accent); }
.btn-accent:hover { background: var(--c-accent-hover); border-color: var(--c-accent-hover); }
.btn-outline { background: transparent; color: var(--c-dark); border-color: var(--c-border-dark); }
.btn-outline:hover { border-color: var(--c-accent); color: var(--c-accent); }
.btn-lg { padding: .875rem 2rem; font-size: 1rem; }
.btn-sm { padding: .4rem .875rem; font-size: .8125rem; }

/* =========================================================
   WOOCOMMERCE – PRODUCT LOOP
   ========================================================= */
ul.products { list-style: none !important; padding: 0 !important; margin: 0 !important; display: grid !important; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1.25rem; }

li.product { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; transition: box-shadow var(--transition), border-color var(--transition); }
li.product:hover { box-shadow: 0 4px 20px rgba(0,0,0,.09); border-color: var(--c-accent); }

li.product .woocommerce-loop-product__link { display: flex; flex-direction: column; flex: 1; text-decoration: none !important; }
li.product img { width: 100%; aspect-ratio: 1/1; object-fit: contain; background: var(--c-bg-alt); padding: 1rem; transition: transform 300ms ease; }
li.product:hover img { transform: scale(1.04); }

li.product .product-info { padding: .875rem 1rem 1rem; flex: 1; display: flex; flex-direction: column; }
li.product .woocommerce-loop-product__title { font-family: var(--font-body); font-size: .875rem; font-weight: 600; color: var(--c-text); margin: 0 0 .35rem; line-height: 1.4; }
li.product .price { font-size: .875rem; font-weight: 700; color: var(--c-dark); margin: 0 0 .75rem; }
li.product .price del { color: var(--c-text-muted); font-weight: 400; margin-right: .35rem; }
li.product .price ins { text-decoration: none; color: var(--c-error); }

li.product .button, li.product .add_to_cart_button {
  display: block !important; width: 100%; text-align: center;
  background: var(--c-dark); color: #fff !important;
  border: none; border-radius: var(--r-md);
  padding: .625rem 1rem; font-size: .8125rem; font-weight: 600;
  cursor: pointer; transition: background var(--transition);
  margin-top: auto; text-decoration: none !important;
}
li.product .button:hover, li.product .add_to_cart_button:hover { background: var(--c-accent); }

span.onsale { position: absolute; top: .75rem; left: .75rem; background: var(--c-error); color: #fff; font-size: .6875rem; font-weight: 700; padding: 2px 8px; border-radius: 20px; text-transform: uppercase; letter-spacing: .04em; z-index: 1; }

/* =========================================================
   WOOCOMMERCE – SHOP TOOLBAR
   ========================================================= */
.woocommerce-notices-wrapper + .woocommerce-result-count { margin-top: 0; }
.woocommerce-result-count { font-size: .875rem; color: var(--c-text-muted); margin: 0; }
.woocommerce-ordering select { border: 1px solid var(--c-border-dark); border-radius: var(--r-md); padding: .4rem .75rem; font-size: .875rem; background: var(--c-bg-card); cursor: pointer; }

/* =========================================================
   SHOP LAYOUT
   ========================================================= */
.shop-layout { display: grid; grid-template-columns: 240px 1fr; gap: 2rem; align-items: start; }
@media (max-width: 860px) { .shop-layout { grid-template-columns: 1fr; } }
.shop-sidebar { position: sticky; top: calc(var(--hdr-h) + 1.5rem); }

/* =========================================================
   SIDEBAR / WIDGETS
   ========================================================= */
.widget { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.125rem; margin-bottom: 1rem; }
.widgettitle, .widget-title { font-family: var(--font-body); font-size: .8125rem; font-weight: 700; color: var(--c-dark); text-transform: uppercase; letter-spacing: .07em; margin: 0 0 .875rem; padding-bottom: .75rem; border-bottom: 1px solid var(--c-border); }
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget ul li { padding: .25rem 0; font-size: .875rem; }
.widget ul li a { color: var(--c-text-muted); display: flex; justify-content: space-between; transition: color var(--transition); }
.widget ul li a:hover { color: var(--c-accent); text-decoration: none; }
.widget ul li .count { color: var(--c-text-light); font-size: .75rem; }
.price_slider_amount { display: flex; align-items: center; justify-content: space-between; font-size: .875rem; margin-top: .5rem; }
.price_slider_amount button { background: var(--c-dark); color: #fff; border: none; border-radius: var(--r-sm); padding: .35rem .75rem; font-size: .75rem; cursor: pointer; }

/* =========================================================
   WOOCOMMERCE – SINGLE PRODUCT
   ========================================================= */
.single-product div.product { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 700px) { .single-product div.product { grid-template-columns: 1fr; gap: 1.5rem; } }

.single-product .woocommerce-product-gallery { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--c-border); background: var(--c-bg-alt); }
.single-product .entry-summary { display: flex; flex-direction: column; gap: .875rem; }
.single-product .product_title { font-size: clamp(1.4rem, 3vw, 2rem); margin: 0; }
.single-product .price { font-size: 1.5rem; font-weight: 700; }
.single-product .woocommerce-product-details__short-description { font-size: .9375rem; color: var(--c-text-muted); border-top: 1px solid var(--c-border); border-bottom: 1px solid var(--c-border); padding: 1rem 0; }

.single-product form.cart { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.single-product form.cart .qty { width: 70px; padding: .75rem; border: 1px solid var(--c-border-dark); border-radius: var(--r-md); text-align: center; }
.single-product .single_add_to_cart_button { flex: 1; min-width: 160px; background: var(--c-accent); color: #fff !important; border: none; border-radius: var(--r-md); padding: .875rem 2rem; font-size: 1rem; font-weight: 700; cursor: pointer; transition: background var(--transition); }
.single-product .single_add_to_cart_button:hover { background: var(--c-accent-hover); }

.trust-box { display: flex; flex-direction: column; gap: .5rem; background: var(--c-bg-alt); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: 1rem; }
.trust-row { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--c-text-muted); }
.trust-row svg { color: var(--c-success); flex-shrink: 0; }

.woocommerce-tabs .wc-tabs { list-style: none; padding: 0; margin: 0; display: flex; border-bottom: 1px solid var(--c-border); }
.woocommerce-tabs .wc-tabs li a { display: block; padding: .75rem 1.25rem; font-size: .875rem; font-weight: 600; color: var(--c-text-muted); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all var(--transition); }
.woocommerce-tabs .wc-tabs li.active a { color: var(--c-dark); border-bottom-color: var(--c-accent); text-decoration: none; }
.woocommerce-tabs .panel { padding: 1.5rem 0; font-size: .9375rem; line-height: 1.8; color: var(--c-text-muted); }

/* =========================================================
   CART & CHECKOUT
   ========================================================= */
table.shop_table { width: 100%; border-collapse: collapse; font-size: .9375rem; }
table.shop_table th { text-align: left; padding: .75rem 1rem; font-weight: 600; border-bottom: 2px solid var(--c-border); font-size: .8125rem; text-transform: uppercase; letter-spacing: .05em; color: var(--c-text-muted); }
table.shop_table td { padding: 1rem; border-bottom: 1px solid var(--c-border); vertical-align: middle; }
.cart_totals, .order-total { background: var(--c-bg-alt); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.5rem; }

.woocommerce form .form-row { margin-bottom: 1rem; }
.woocommerce form .form-row label { display: block; font-size: .875rem; font-weight: 600; margin-bottom: .35rem; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea { width: 100%; border: 1px solid var(--c-border-dark); border-radius: var(--r-md); padding: .75rem 1rem; font-size: .9375rem; background: var(--c-bg-card); transition: border-color var(--transition); }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus { outline: none; border-color: var(--c-accent); }

#place_order { width: 100%; background: var(--c-accent); color: #fff; border: none; border-radius: var(--r-md); padding: 1.125rem; font-size: 1.0625rem; font-weight: 700; cursor: pointer; transition: background var(--transition); }
#place_order:hover { background: var(--c-accent-hover); }

/* =========================================================
   NOTICES
   ========================================================= */
.woocommerce-message { background: var(--c-success-bg); color: var(--c-success); border-left: 3px solid #10B981; border-radius: var(--r-md); padding: 1rem 1.25rem; margin-bottom: 1.5rem; font-size: .9375rem; display: flex; align-items: center; gap: .75rem; list-style: none; }
.woocommerce-error { background: var(--c-error-bg); color: var(--c-error); border-left: 3px solid #EF4444; border-radius: var(--r-md); padding: 1rem 1.25rem; margin-bottom: 1.5rem; list-style: none; }
.woocommerce-info { background: var(--c-info-bg); color: var(--c-info); border-left: 3px solid #3B82F6; border-radius: var(--r-md); padding: 1rem 1.25rem; margin-bottom: 1.5rem; list-style: none; }

/* =========================================================
   PAGINATION
   ========================================================= */
.woocommerce-pagination { margin-top: 2rem; }
.woocommerce-pagination ul { list-style: none; padding: 0; margin: 0; display: flex; gap: .4rem; justify-content: center; flex-wrap: wrap; }
.woocommerce-pagination ul li a, .woocommerce-pagination ul li span { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1px solid var(--c-border-dark); border-radius: var(--r-sm); font-size: .875rem; font-weight: 600; color: var(--c-text-muted); transition: all var(--transition); }
.woocommerce-pagination ul li a:hover { border-color: var(--c-accent); color: var(--c-accent); text-decoration: none; }
.woocommerce-pagination ul li span.current { background: var(--c-dark); color: #fff; border-color: var(--c-dark); }

/* =========================================================
   HERO
   ========================================================= */
.site-hero { background: var(--c-dark); color: #fff; padding: 5rem 0 4rem; text-align: center; }
.site-hero h1 { color: var(--c-accent); margin-bottom: 1rem; }
.site-hero p { color: rgba(255,255,255,.65); font-size: 1.125rem; max-width: 600px; margin: 0 auto 2rem; }
.hero-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* =========================================================
   CATEGORY CARDS
   ========================================================= */
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(175px, 1fr)); gap: 1rem; }
.cat-card { display: block; background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; text-decoration: none !important; transition: box-shadow var(--transition), border-color var(--transition); }
.cat-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); border-color: var(--c-accent); }
.cat-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.cat-card-img-placeholder { width: 100%; aspect-ratio: 4/3; background: var(--c-bg-alt); display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.cat-card-body { padding: .75rem 1rem; }
.cat-card-name { font-size: .875rem; font-weight: 600; color: var(--c-text); }
.cat-card-count { font-size: .75rem; color: var(--c-text-muted); }

/* =========================================================
   SERVICE CARDS
   ========================================================= */
.service-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1.25rem; }
.service-card { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.5rem; }
.service-icon { font-size: 1.75rem; margin-bottom: .75rem; }
.service-title { font-family: var(--font-body); font-size: .9375rem; font-weight: 700; margin: 0 0 .5rem; }
.service-desc { font-size: .875rem; color: var(--c-text-muted); margin: 0 0 1rem; }

/* =========================================================
   SECTIONS
   ========================================================= */
.section { padding: 3rem 0; }
.section-alt { padding: 3rem 0; background: var(--c-bg-alt); }
.section-title { margin-bottom: 1.5rem; }
.section-title h2 { margin: 0; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { background: var(--c-dark); color: rgba(255,255,255,.5); padding: 3.5rem 0 1.5rem; margin-top: 4rem; font-size: .875rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
@media (max-width: 860px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-brand-name { font-family: var(--font-head); color: var(--c-accent); font-size: 1.25rem; display: block; margin-bottom: .5rem; }
.footer-tagline { font-size: .8125rem; color: rgba(255,255,255,.35); line-height: 1.6; margin-bottom: 1rem; }
.footer-credit { font-size: .6875rem; color: rgba(255,255,255,.2); }
.footer-col h4 { font-family: var(--font-body); font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: rgba(255,255,255,.65); margin: 0 0 .875rem; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col ul li { margin-bottom: .35rem; }
.footer-col ul li a { font-size: .8125rem; color: rgba(255,255,255,.4); transition: color var(--transition); }
.footer-col ul li a:hover { color: var(--c-accent); text-decoration: none; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.07); padding-top: 1.5rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: .75rem; font-size: .75rem; color: rgba(255,255,255,.28); }
.footer-bottom a { color: rgba(217,119,6,.65); }
.footer-bottom a:hover { color: var(--c-accent); }

/* =========================================================
   UTILITIES
   ========================================================= */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.text-muted { color: var(--c-text-muted); }
.mt-2 { margin-top: 2rem; }
.mb-2 { margin-bottom: 2rem; }

/* =========================================================
   PRINT
   ========================================================= */
@media print {
  .site-header, .site-footer, .shop-sidebar, .woocommerce-tabs { display: none !important; }
  body { font-size: 11pt; color: #000; background: #fff; }
}

/* =========================================================
   KATEGORIRAD – underkategorier ovanför produktgridet
   ========================================================= */
.la-subcat-nav {
  margin-bottom: 1.75rem;
  padding-bottom: 1.75rem;
  border-bottom: 1px solid var(--c-border);
}

.la-subcat-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--c-text-muted);
  margin-bottom: .75rem;
}

.la-subcat-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .625rem;
}

.la-subcat-card {
  display: flex;
  align-items: center;
  gap: .625rem;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: .5rem .875rem .5rem .5rem;
  text-decoration: none !important;
  transition: border-color var(--transition), box-shadow var(--transition);
  min-width: 0;
}

.la-subcat-card:hover {
  border-color: var(--c-accent);
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
}

.la-subcat-card img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  border-radius: 7px;
  background: var(--c-bg-alt);
  padding: .25rem;
  flex-shrink: 0;
}

.la-subcat-name {
  display: flex;
  flex-direction: column;
  font-size: .875rem;
  font-weight: 600;
  color: var(--c-text);
  line-height: 1.2;
  white-space: nowrap;
}

.la-subcat-name small {
  font-size: .75rem;
  font-weight: 400;
  color: var(--c-text-muted);
  margin-top: 1px;
}

.la-subcat-arrow {
  font-size: 1.125rem;
  color: var(--c-border-dark);
  margin-left: .25rem;
  transition: color var(--transition);
  flex-shrink: 0;
}

.la-subcat-card:hover .la-subcat-arrow {
  color: var(--c-accent);
}
