/**
 * Topson – WooCommerce-stilmall
 * ---------------------------------------------------------------
 * Denna fil hålls medvetet separat från temats style.css. Den laddas
 * enbart in när WooCommerce är aktivt (se inc/woocommerce.php) och
 * innehåller allt som rör butiken: produktlista, produktkort,
 * produktsida, attributväljare och varukorgs-/kontoikonerna i headern.
 *
 * Färger/radier återanvänder samma CSS-variabler som resten av temat
 * (se :root i style.css). --wc-dark definieras lokalt här eftersom
 * den bara används på butikssidorna.
 */

:root {
    --wc-dark: #0d0d0d;
}

/* ───────────────────────────────────────────────────────────────
   Stjärnbetyg (.star-rating). WooCommerce ritar normalt stjärnorna
   med ett eget ikontypsnitt som laddas via plugin-CSS:en – eftersom
   vi stänger av WooCommerce:s standard-stylesheet (se inc/woocommerce.php)
   laddas aldrig det typsnittet, så vi ritar stjärnorna själva med
   rena Unicode-tecken istället. Samma teknik som WooCommerce: ett
   gråtonat "spår" av 5 stjärnor i botten, och ett gult lager ovanpå
   som klipps till betygets bredd (span-elementets inline style="width:X%").
   ─────────────────────────────────────────────────────────────── */
.star-rating {
    position: relative;
    display: inline-block;
    width: 5.4em;
    height: 1.2em;
    line-height: 1.2em;
    font-size: 14px;
    letter-spacing: .2em;
    overflow: hidden;
    vertical-align: middle;
}

.star-rating::before {
    content: "\2605\2605\2605\2605\2605";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    color: #e5e7eb;
}

.star-rating span {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    overflow: hidden;
    font-size: 0;
    color: transparent;
}

.star-rating span::before {
    content: "\2605\2605\2605\2605\2605";
    position: absolute;
    top: 0;
    left: 0;
    font-size: 14px;
    letter-spacing: .2em;
    color: var(--action-yellow, #d1a12e);
    white-space: nowrap;
}

/* ───────────────────────────────────────────────────────────────
   Känd WooCommerce-bugg: <ul class="products"> får automatiskt en
   clearfix via ::before/::after (content:"";display:table;). I
   kombination med CSS Grid (se nedan) skapar de pseudo-elementen en
   extra, tom "spökruta" som förskjuter hela produktrutnätet ett
   steg. Vi nollställer dem explicit innan griden sätts.
   ─────────────────────────────────────────────────────────────── */
ul.products::before,
ul.products::after,
ul.products li.product::before,
ul.products li.product::after {
    content: none !important;
    display: none !important;
}

/* ─── Produkter på startsidan ────────────────────────────────── */
.front-shop-section {
    padding: 24px 0 64px;
}

.front-shop-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 24px;
}

.section-eyebrow {
    display: inline-block;
    margin-bottom: 8px;
    padding: 4px 10px;
    background: var(--action-yellow, #d1a12e);
    color: var(--wc-dark);
    font-family: "Hanken Grotesk", sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    border-radius: 4px;
}

.front-shop-heading h2 {
    margin-bottom: 0;
    font-size: 28px;
    text-transform: uppercase;
    letter-spacing: -.01em;
}

.front-shop-link {
    font-weight: 700;
    font-size: 14px;
    color: var(--wc-dark);
    text-decoration: underline;
    white-space: nowrap;
}

/* ─── Butikslayout: filterpanel + produktlista ──────────────── */
.shop-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 40px 0 80px;
    align-items: start;
}

@media (min-width: 960px) {
    .shop-layout {
        grid-template-columns: 260px 1fr;
    }
}

.shop-sidebar {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.woocommerce-products-header__title {
    margin-bottom: 8px;
}

/* ─── Produktlista (arkiv/kategori) ─────────────────────────── */
ul.products {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--gutter, 28px) !important;
    list-style: none !important;
    margin: 40px 0 0 !important;
    padding: 0 !important;
}

@media (min-width: 480px) {
    ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (min-width: 900px) {
    ul.products {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 1600px) {
    ul.products {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Butikens produktlista har en filterpanel bredvid sig (se .shop-layout),
   så det tillgängliga utrymmet för korten är betydligt smalare än hela
   webbläsarfönstret. Brytpunkterna ovan är satta efter fönsterbredd och
   ger därför för många/små kolumner här – vi begränsar därför till max
   2 kolumner (3 först på riktigt breda skärmar) så att korten blir
   dubbelt så breda i den här specifika layouten.
   OBS: !important används genomgående här eftersom WooCommerce (från
   version 8.6+) kan ladda sin egen grid-CSS för ul.products om ett
   plugin eller en cache-lösning råkar återaktivera den – utan !important
   kan den CSS:en annars vinna och klämma ihop korten igen. */
.shop-content ul.products {
    grid-template-columns: 1fr !important;
}

@media (min-width: 560px) {
    .shop-content ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (min-width: 1700px) {
    .shop-content ul.products {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

ul.products li.product-card-item {
    width: 100% !important;
    margin: 0 !important;
    float: none !important;
    list-style: none;
}

.woocommerce-result-count,
.woocommerce-ordering {
    margin: 0 0 16px;
}

.woocommerce-ordering select.orderby {
    display: inline-block;
    padding: 10px 36px 10px 16px;
    font-family: inherit;
    font-size: 15px;
    color: #374151;
    background-color: #f9fafb;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .05);
    cursor: pointer;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 14px;
    transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}

.woocommerce-ordering select.orderby:hover {
    border-color: #9ca3af;
    background-color: #fff;
}

.woocommerce-ordering select.orderby:focus {
    border-color: #6b7280;
    box-shadow: 0 0 0 3px rgba(107, 114, 128, .15);
}

.woocommerce-ordering select.orderby option {
    background-color: #fff;
    color: #374151;
}

/* ─── Produktkort ────────────────────────────────────────────── */
.product-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.product-card .onsale {
    position: absolute;
    top: 12px;
    left: 12px;
    background: var(--action-yellow, #d1a12e);
    color: var(--wc-dark);
    font-weight: 800;
    font-size: 12px;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: var(--radius-default, 4px);
    z-index: 1;
}

.product-card {
    position: relative;
    background: #fff;
    padding: 20px;
    border-radius: 10px;
    border: 1px solid #eef0f2;
    box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
    transition: box-shadow .2s ease, transform .2s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.product-card:hover {
    box-shadow: 0 16px 32px rgba(16, 24, 40, .09);
    transform: translateY(-4px);
}

.product-card img {
    width: 100%;
    aspect-ratio: 1 / 1.1;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 18px;
    background: #f3f4f6;
    transition: transform .4s ease;
}

.product-card:hover img {
    transform: scale(1.05);
}

.product-card .product-name {
    font-size: 17px;
    margin-bottom: 4px;
}

.product-card .star-rating {
    margin-bottom: 8px;
}

.product-card .price {
    display: block;
    font-weight: 700;
    font-size: 17px;
    color: var(--primary, #0d0d0d);
    margin: 4px 0 18px;
}

.product-card .price del {
    opacity: .5;
    font-weight: 400;
    font-size: 14px;
    margin-right: 8px;
}

.product-card .price ins {
    text-decoration: none;
}

.product-card-footer {
    margin-top: auto;
}

.product-card-footer .button,
.product-card-footer .add_to_cart_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    background: var(--wc-dark);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--radius-default, 4px);
    font-weight: 700;
    text-decoration: none;
    text-align: center;
}

.product-card-footer .button:hover,
.product-card-footer .add_to_cart_button:hover {
    opacity: .9;
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, .15);
}

.product-card-footer .button:active,
.product-card-footer .add_to_cart_button:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0, 0, 0, .1);
}

/* Medan WooCommerce lägger produkten i varukorgen via AJAX. */
.product-card-footer .button.loading,
.product-card-footer .add_to_cart_button.loading {
    opacity: .7;
    pointer-events: none;
    position: relative;
    color: transparent;
}

.product-card-footer .button.loading::after,
.product-card-footer .add_to_cart_button.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 16px;
    margin: -8px 0 0 -8px;
    border: 2px solid rgba(255, 255, 255, .4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: topson-spin .6s linear infinite;
}

@keyframes topson-spin {
    to {
        transform: rotate(360deg);
    }
}

.product-card-footer .added_to_cart {
    display: flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
    margin: 8px auto 0;
    padding: 6px 12px;
    border-radius: 999px;
    background: #ecfdf5;
    color: #15803d;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    animation: topson-fade-in .3s ease both;
}

.product-card-footer .added_to_cart::before {
    font-family: 'Material Symbols Outlined';
    content: "check_circle";
    font-size: 16px;
}

/* ─── Produktsida ────────────────────────────────────────────── */
.woocommerce-main .product {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 40px 0 80px;
}

@media (min-width: 1024px) {
    .woocommerce-main .product {
        grid-template-columns: 1fr 1fr;
        gap: 64px;
    }
}

/* ─── Produktbildspel + zoom vid hover ──────────────────────────
   WooCommerce:s inbyggda zoomfunktion (zoom.js, aktiveras via
   add_theme_support('wc-product-gallery-zoom')) lägger till en
   förstorad kopia av bilden (.zoomImg) absolut-positionerad ovanpå
   originalet när man hovrar, och flyttar den utifrån muspekaren för
   att skapa ett förstoringsglas-liknande resultat. Det kräver att
   behållaren har position:relative + overflow:hidden så att den
   förstorade bilden klipps till rätt yta – annars renders den bara
   som en vanlig, oklippt "kopia" av bilden som skjuter ut nedanför,
   vilket är precis det som såg fel ut innan denna CSS fanns. */
.woocommerce-product-gallery__wrapper {
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce-product-gallery__image {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
    border: 1px solid #eef0f2;
    background: #fafafa;
}

.woocommerce-product-gallery__image a {
    display: block;
    cursor: crosshair;
}

.woocommerce-product-gallery__image img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 10px;
}

.woocommerce-product-gallery__image .zoomImg {
    position: absolute !important;
    top: 0;
    left: 0;
    width: auto !important;
    max-width: none !important;
    background-color: #fff;
    border-radius: 10px;
}

/* Miniatyrbilder under huvudbilden – den valda bilden markeras med
   temats volt-accent istället för en vanlig svart ram, för lite
   energi i gränssnittet. */
.flex-control-thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 16px 0 0;
    padding: 0;
    list-style: none;
}

.flex-control-thumbs li {
    width: 72px;
}

.flex-control-thumbs img {
    display: block;
    width: 100%;
    height: 72px;
    object-fit: cover;
    border-radius: 6px;
    cursor: pointer;
    opacity: .55;
    border: 2px solid transparent;
    transition: opacity .15s ease, border-color .15s ease, transform .15s ease;
}

.flex-control-thumbs img:hover {
    opacity: 1;
    transform: translateY(-2px);
}

.flex-control-thumbs img.flex-active {
    opacity: 1;
    border-color: var(--action-yellow, #d1a12e);
}

.product-info .product_title {
    font-size: 32px;
    font-weight: 800;
    color: var(--primary, #0d0d0d);
    margin-bottom: 12px;
}

.product-info .star-rating {
    margin-bottom: 16px;
}

.product-info-price {
    font-size: 24px;
    font-weight: 700;
    color: var(--primary, #0d0d0d);
    margin-bottom: 24px;
}

.product-info-price del {
    opacity: .5;
    font-weight: 400;
    font-size: 18px;
    margin-right: 10px;
}

.product-info-price ins {
    text-decoration: none;
}

.woocommerce-product-details__short-description {
    margin-bottom: 32px;
    line-height: 1.6;
    color: var(--on-surface-variant, #424750);
}

/* ─── Produktflikar (Beskrivning / Ytterligare information / Recensioner) ─── */
.woocommerce-tabs {
    margin: 24px 0 80px;
}

.woocommerce-tabs ul.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    list-style: none;
    margin: 0 0 32px;
    padding: 0;
    border-bottom: 1px solid #e5e7eb;
}

.woocommerce-tabs ul.tabs li {
    margin: 0;
}

.woocommerce-tabs ul.tabs li a {
    display: inline-block;
    padding: 14px 20px;
    color: #6b7280;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}

.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
    color: var(--wc-dark);
    border-bottom-color: var(--wc-dark);
}

.woocommerce-tabs .woocommerce-Tabs-panel {
    max-width: 760px;
    line-height: 1.7;
    color: #374151;
}

.woocommerce-tabs .woocommerce-Tabs-panel h2 {
    font-size: 22px !important;
    font-weight: 800;
    color: var(--wc-dark) !important;
    margin-bottom: 20px;
}

.woocommerce-Tabs-panel table.shop_attributes {
    width: 100%;
    border-collapse: collapse;
    margin-top: 8px;
}

.woocommerce-Tabs-panel table.shop_attributes th,
.woocommerce-Tabs-panel table.shop_attributes td {
    padding: 12px;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
    font-size: 14px;
}

.woocommerce-Tabs-panel table.shop_attributes th {
    width: 200px;
    color: #6b7280;
    font-weight: 600;
}

/* Recensioner */
#reviews .commentlist {
    list-style: none;
    margin: 0 0 32px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

#reviews .comment_container {
    display: flex;
    gap: 16px;
}

#reviews .comment-text {
    flex: 1;
    padding-bottom: 20px;
    border-bottom: 1px solid #e5e7eb;
}

#reviews .avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    object-fit: cover;
    aspect-ratio: 1 / 1;
    flex-shrink: 0;
}

#reviews .woocommerce-review__author {
    font-weight: 700;
    color: var(--wc-dark);
    margin-right: 8px;
}

#reviews .woocommerce-review__dash {
    color: #9ca3af;
    margin-right: 8px;
}

#reviews .star-rating {
    margin: 6px 0;
}

#review_form_wrapper h3 {
    font-size: 20px !important;
    font-weight: 800;
    color: var(--wc-dark) !important;
    margin-bottom: 16px;
}

.comment-form-rating label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #4b5563;
    margin-bottom: 8px;
}

.comment-form-rating p.stars {
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
}

.comment-form-rating p.stars a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    text-decoration: none;
    /* Den riktiga texten ("1 av 5 stjärnor" osv.) finns kvar i DOM:en
       för skärmläsare men görs osynlig här – vi ritar en egen
       stjärnikon istället via ::before nedan. */
    font-size: 0;
    color: transparent;
}

/* Grundläge: alla stjärnor gråa (inget hovrat, inget valt än). */
.comment-form-rating p.stars a::before {
    content: "\2605";
    font-size: 28px;
    line-height: 1;
    color: #d1d5db;
    transition: color .1s ease;
}

/* CSS kan bara selektera SENARE syskon (via ~), inte tidigare. Så
   istället för att försöka färga "den man hovrar och allt innan den"
   guld, gör vi tvärtom: när man hovrar raden färgas ALLA stjärnor
   guld, och sen gråas bara de som kommer EFTER (till höger om) just
   den man pekar på – det ger exakt samma resultat (1..N guld, N+1..5
   grå) men går faktiskt att uttrycka i CSS, med stjärna 1 längst till
   vänster som det ska vara. */
.comment-form-rating p.stars:hover a::before {
    color: var(--action-yellow, #d1a12e);
}

.comment-form-rating p.stars a:hover ~ a::before {
    color: #d1d5db;
}

/* Samma logik permanent för det betyg som faktiskt är valt (klassen
   "active" sätts av WooCommerce vid klick), när man inte hovrar. */
.comment-form-rating p.stars:has(a.active):not(:hover) a::before {
    color: var(--action-yellow, #d1a12e);
}

.comment-form-rating p.stars:has(a.active):not(:hover) a.active ~ a::before {
    color: #d1d5db;
}

.comment-form-comment label,
.comment-form-author label,
.comment-form-email label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #4b5563;
    margin-bottom: 6px;
}

#reviews .form-submit {
    margin-top: 16px;
}

/* ─── Attributboxar (ersätter dropdown) ─────────────────────── */
.dm-variation-buttons {
    margin-bottom: 24px;
}

.dm-attribute-group {
    margin-bottom: 24px;
}

.dm-attribute-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.dm-attribute-label {
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    font-size: 13px;
    color: var(--wc-dark);
}

.dm-attribute-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.dm-attribute-option {
    display: block;
}

.dm-attribute-radio {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.dm-attribute-box {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 14px 8px;
    border: 1px solid #e2e8f0;
    border-radius: var(--radius-default, 4px);
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    user-select: none;
    transition: background-color .15s ease, color .15s ease, border-color .15s ease, transform .1s ease;
}

.dm-attribute-box:active {
    transform: scale(.95);
}

.dm-attribute-radio:checked + .dm-attribute-box {
    background: var(--wc-dark);
    border-color: var(--wc-dark);
    color: #fff;
}

.dm-attribute-radio:focus-visible + .dm-attribute-box {
    outline: 2px solid var(--action-yellow, #d1a12e);
    outline-offset: 2px;
}

.dm-attribute-box:hover {
    border-color: var(--wc-dark);
}

/* Kombinationer som WooCommerce räknat ut inte finns (t.ex. en
   Storlek+Färg-kombination som saknar egen variant) – se
   assets/js/variations.js. */
.dm-attribute-radio:disabled + .dm-attribute-box {
    color: #d1d5db;
    border-color: #f0f1f3;
    background: #fafafa;
    cursor: not-allowed;
    text-decoration: line-through;
}

.dm-attribute-radio:disabled + .dm-attribute-box:hover {
    border-color: #f0f1f3;
}

.reset_variations {
    display: inline-block;
    margin-top: 4px;
    font-size: 13px;
}

/* Riktiga <select>-fält: dolda visuellt men fortsatt tillgängliga
   för skärmläsare och tangentbordsnavigering (inte display:none). */
.dm-hidden-selects {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* ─── Lägg i varukorg-knappen på produktsidan ───────────────── */
.single_variation_wrap {
    margin-top: 8px;
}

.quantity {
    display: inline-block;
    margin-bottom: 16px;
}

.quantity .qty {
    width: 80px;
    padding: 14px;
    border: 1px solid #d1d5db;
    border-radius: var(--radius-default, 4px);
    font-family: inherit;
    font-size: 16px;
    background-color: #f9fafb;
    color: #1f2937;
}

.quantity .qty:hover {
    border-color: #9ca3af;
}

.quantity .qty:focus {
    border-color: #6b7280;
    outline: none;
    box-shadow: 0 0 0 3px rgba(107, 114, 128, .15);
    background-color: #fff;
}

.single_add_to_cart_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    background: var(--wc-dark);
    color: #fff;
    padding: 20px 24px;
    border-radius: var(--radius-default, 4px);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 15px;
}

.single_add_to_cart_button::before {
    font-family: 'Material Symbols Outlined';
    content: "shopping_bag";
    font-size: 20px;
}

.single_add_to_cart_button.disabled {
    opacity: .5;
    cursor: not-allowed;
}

.woocommerce-variation-price {
    margin-bottom: 8px;
}

.woocommerce-variation-availability {
    margin-bottom: 16px;
    font-size: 14px;
}

/* ─── Filterpanel: kategorier, pris, attribut ───────────────── */
.shop-filter-group {
    padding-bottom: 28px;
    border-bottom: 1px solid #e5e7eb;
}

.shop-filter-group:last-child {
    border-bottom: none;
}

.shop-filter-group .shop-filter-title,
h2.shop-filter-title {
    font-size: 13px !important;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--wc-dark) !important;
    margin-bottom: 16px !important;
    font-family: inherit !important;
}

.shop-category-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.shop-category-list li {
    margin: 0;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    font-size: 13px;
    color: #9ca3af;
}

.shop-category-list a {
    display: inline-block;
    padding: 8px 10px;
    border-radius: var(--radius-default, 4px);
    border-left: 3px solid transparent;
    color: #4b5563;
    text-decoration: none;
    font-size: 14px;
    transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}

.shop-category-list a:hover {
    background: #f3f4f6;
    color: var(--wc-dark);
}

.shop-category-list .current-cat > a {
    background: #f3f4f6;
    border-left-color: var(--action-yellow, #d1a12e);
    color: var(--wc-dark);
    font-weight: 700;
}

.shop-category-list .children {
    list-style: none;
    margin: 4px 0 4px 12px;
    padding: 0;
}

.shop-filter-clear {
    display: inline-block;
    margin-top: 12px;
    font-size: 13px;
    color: #6b7280;
}

/* WooCommerce prisfilter-widget */
.widget_price_filter .price_slider {
    margin-bottom: 16px;
}

.widget_price_filter .price_slider_amount {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 13px;
    color: #4b5563;
}

.widget_price_filter .price_slider_amount .button {
    background: #f3f4f6;
    color: #374151;
    border: 1px solid #d1d5db;
    padding: 8px 14px;
    border-radius: var(--radius-default, 4px);
    font-weight: 600;
    font-size: 13px;
}

.widget_price_filter .price_slider_amount .button:hover {
    background: #e5e7eb;
}

.widget_price_filter .ui-slider {
    position: relative;
    height: 4px;
    background: #e5e7eb;
    border-radius: 999px;
    margin: 16px 4px;
}

.widget_price_filter .ui-slider-range {
    position: absolute;
    height: 100%;
    background: #6b7280;
    border-radius: 999px;
}

.widget_price_filter .ui-slider-handle {
    position: absolute;
    top: 50%;
    width: 16px;
    height: 16px;
    margin-left: -8px;
    transform: translateY(-50%);
    background: #fff;
    border: 2px solid #6b7280;
    border-radius: 50%;
    cursor: pointer;
    outline: none;
}

/* WooCommerce attributfilter (kryssrutor) */
.widget_layered_nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.widget_layered_nav li a {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding: 6px 10px;
    border-radius: var(--radius-default, 4px);
    color: #4b5563;
    text-decoration: none;
    font-size: 14px;
}

.widget_layered_nav li a:hover,
.widget_layered_nav li.chosen a {
    background: #f3f4f6;
    color: var(--wc-dark);
}

/* ─── Generella WooCommerce-knappar (t.ex. logga in, registrera,
   skicka recension) – specifika knappar som prisfiltrets "Filtrera"
   och #place_order är mer specifika och vinner ändå över denna. ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-tabs #respond input#submit,
.woocommerce-Button {
    background: var(--wc-dark);
    color: #fff;
    border: none;
    padding: 14px 24px;
    border-radius: var(--radius-default, 4px);
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    display: inline-block;
    text-align: center;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    opacity: .9;
    color: #fff;
}

/* ─── Formulärelement på butikssidor: grå, modern design ────── */
.woocommerce form .form-row {
    margin-bottom: 16px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout select,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-form-login input.input-text,
.woocommerce-form-register input.input-text,
.woocommerce-MyAccount-content input.input-text,
.woocommerce-MyAccount-content select,
.woocommerce-MyAccount-content textarea,
.comment-form-author input,
.comment-form-email input,
.comment-form-url input,
.comment-form-comment textarea {
    display: block;
    box-sizing: border-box;
    width: 100%;
    padding: 12px 14px;
    font-family: inherit;
    font-size: 15px;
    background-color: #f9fafb;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    color: #1f2937;
}

.comment-form-comment textarea {
    min-height: 180px;
    resize: vertical;
}

.woocommerce form .form-row input.input-text:hover,
.woocommerce form .form-row textarea:hover,
.woocommerce form .form-row select:hover,
.woocommerce-form-login input.input-text:hover,
.woocommerce-form-register input.input-text:hover,
.comment-form-author input:hover,
.comment-form-email input:hover,
.comment-form-url input:hover,
.comment-form-comment textarea:hover {
    border-color: #9ca3af;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.woocommerce-form-login input.input-text:focus,
.woocommerce-form-register input.input-text:focus,
.comment-form-author input:focus,
.comment-form-email input:focus,
.comment-form-url input:focus,
.comment-form-comment textarea:focus {
    border-color: #6b7280;
    outline: none;
    box-shadow: 0 0 0 3px rgba(107, 114, 128, .15);
    background-color: #fff;
}

.woocommerce form .show-password-input {
    color: #6b7280;
}

.woocommerce-form-login__rememberme {
    color: #4b5563;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
    border: 1px solid #e5e7eb;
    background: #f9fafb;
}

/* ─── Mitt konto: navigering som horisontella flikar ────────── */
.woocommerce-account .woocommerce-MyAccount-navigation {
    margin-bottom: 32px;
    border-bottom: 1px solid #e5e7eb;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li {
    margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: inline-block;
    padding: 14px 18px;
    color: #6b7280;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
    color: var(--wc-dark);
    border-bottom-color: #d1d5db;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
    color: var(--wc-dark);
    border-bottom-color: var(--wc-dark);
}

.u-columns {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
}

@media (min-width: 700px) {
    .u-columns {
        grid-template-columns: 1fr 1fr;
    }
}

.woocommerce-form-login,
.woocommerce-form-register {
    border: 1px solid #e5e7eb;
    border-radius: var(--radius-lg, 8px);
    padding: 32px;
    background: #f9fafb;
}

.woocommerce-form-login h2,
.woocommerce-form-register h2 {
    font-size: 18px;
    font-weight: 800;
    color: var(--wc-dark);
    margin-bottom: 20px;
}

.woocommerce-form-row label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #4b5563;
    margin-bottom: 6px;
}

.woocommerce-form-login .button,
.woocommerce-form-register .button,
.woocommerce-ResetPassword .button {
    width: 100%;
    margin-top: 8px;
}

.woocommerce-LostPassword {
    margin-top: 12px;
    font-size: 13px;
}

.woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-MyAccount-content button.button {
    background: var(--wc-dark);
    color: #fff;
    border: none;
    padding: 14px 24px;
    border-radius: var(--radius-default, 4px);
    font-weight: 700;
}

.woocommerce-MyAccount-content table.woocommerce-orders-table,
.woocommerce-MyAccount-content table.shop_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 24px;
}

.woocommerce-MyAccount-content table.woocommerce-orders-table th,
.woocommerce-MyAccount-content table.woocommerce-orders-table td,
.woocommerce-MyAccount-content table.shop_table th,
.woocommerce-MyAccount-content table.shop_table td {
    padding: 12px;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
    font-size: 14px;
}

.woocommerce-MyAccount-content .woocommerce-MyAccount-orders-status {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #4b5563;
    font-size: 12px;
    font-weight: 700;
}

.woocommerce-Addresses {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

@media (min-width: 700px) {
    .woocommerce-Addresses {
        grid-template-columns: 1fr 1fr;
    }
}

.woocommerce-Address {
    border: 1px solid #e5e7eb;
    border-radius: var(--radius-lg, 8px);
    padding: 24px;
}

.woocommerce-Address-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.woocommerce-Address-title h3 {
    font-size: 16px !important;
    font-weight: 800;
    color: var(--wc-dark) !important;
}

.woocommerce-Address-title .edit {
    font-size: 13px;
    color: #6b7280;
}

/* ─── Varukorgs-/kontoikoner i headern ──────────────────────── */
.header-icon-link {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full, 9999px);
    color: var(--primary, #0d0d0d);
    background: transparent;
    text-decoration: none;
}

.header-icon-link:hover {
    background: rgba(13, 13, 13, .08);
    opacity: 1;
}

@keyframes topson-cart-pop {
    0% {
        transform: scale(.4);
        opacity: 0;
    }

    60% {
        transform: scale(1.2);
        opacity: 1;
    }

    100% {
        transform: scale(1);
    }
}

.cart-icon-link .cart-count {
    position: absolute;
    top: -2px;
    right: -2px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 999px;
    background: var(--action-yellow, #d1a12e);
    color: var(--primary, #0d0d0d);
    font-size: 11px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    animation: topson-cart-pop .4s ease;
}

/* ─── Sök i headern ──────────────────────────────────────────── */
.header-search {
    position: relative;
}

.header-search-toggle {
    border: none;
    cursor: pointer;
}

.header-search-panel {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: min(360px, calc(100vw - 32px));
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 16px 40px rgba(16, 24, 40, .12);
    padding: 12px;
    z-index: 60;
}

.header-search-form {
    display: flex;
    align-items: center;
    gap: 8px;
}

.header-search-input {
    flex: 1;
    padding: 10px 14px;
    background-color: #f9fafb;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    color: #1f2937;
    font-size: 15px;
}

.header-search-input:hover {
    border-color: #9ca3af;
}

.header-search-input:focus {
    outline: none;
    border-color: #6b7280;
    background-color: #fff;
    box-shadow: 0 0 0 3px rgba(107, 114, 128, .15);
}

.header-search-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: #6b7280;
    cursor: pointer;
}

.header-search-close:hover {
    background: #f3f4f6;
    color: var(--wc-dark);
}

.header-search-results {
    margin-top: 10px;
    max-height: 420px;
    overflow-y: auto;
}

.header-search-results.is-loading {
    opacity: .5;
}

.header-search-empty {
    padding: 16px 8px;
    color: #6b7280;
    font-size: 14px;
    text-align: center;
}

.header-search-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.header-search-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px;
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
}

.header-search-item:hover {
    background: #f3f4f6;
}

.header-search-thumb {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 6px;
    overflow: hidden;
    background: #f3f4f6;
}

.header-search-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.header-search-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.header-search-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--wc-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.header-search-price {
    font-size: 13px;
    color: #6b7280;
}

@media (max-width: 480px) {
    .header-search-panel {
        position: fixed;
        top: 72px;
        left: 16px;
        right: 16px;
        width: auto;
    }
}

/* ─── Varukorg / kassa (grundläggande läsbarhet) ────────────── */
.woocommerce-cart-form table.shop_table,
.woocommerce-checkout table.shop_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 32px;
}

.woocommerce-cart-form table.shop_table th,
.woocommerce-cart-form table.shop_table td,
.woocommerce-checkout table.shop_table th,
.woocommerce-checkout table.shop_table td {
    padding: 12px;
    border-bottom: 1px solid #e2e8f0;
    text-align: left;
}

#place_order,
.checkout-button {
    background: var(--wc-dark);
    color: #fff;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: 18px 24px;
    border-radius: var(--radius-default, 4px);
    width: 100%;
    text-align: center;
    display: block;
}
