/* ==========================================================================
   Absolu Fragrance - Complete Custom Styles
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Reset and Base
   -------------------------------------------------------------------------- */

@font-face {
    font-family: "OmegaCT";
    src: url("assets/fonts/OmegaCTRegular.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    /* Brand palette */
    --absolu-primary: #D50A31;
    --absolu-primary-dark: #A30825;
    --absolu-primary-darker: #7A061B;
    --absolu-secondary: #D1B488;
    --absolu-secondary-light: #E8D5B8;

    /* Text */
    --absolu-text: #2C2D33;
    --absolu-text-light: #54595F;

    /* Neutrals */
    --absolu-white: #ffffff;
    --absolu-border: #e8e8e8;
    --absolu-bg-light: #f8f8f8;
    --absolu-muted: #999;
    --absolu-strike: #bbb;
    --absolu-input-active: #757575;

    /* Feedback */
    --absolu-success: #2d6a3f;
    --absolu-error: #a94442;

    /* System */
    --absolu-font: "OmegaCT", "Exo 2", sans-serif;
    --absolu-font-body: "Poppins", sans-serif;
    --absolu-container: 1400px;
    --absolu-gap: 20px;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

*:focus {
    outline: none;
}

::selection {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

body {
    font-family: var(--absolu-font-body);
    font-size: 16px;
    color: var(--absolu-text);
    background: var(--absolu-white);
    margin: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.7;
}

a,
a:where(:not(.wp-element-button)) {
    color: var(--absolu-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover {
    color: var(--absolu-primary-dark);
}

img {
    max-width: 100%;
    height: auto;
}

.absolu-container {
    max-width: var(--absolu-container);
    margin: 0 auto;
    padding: 0 var(--absolu-gap);
}

/* --------------------------------------------------------------------------
   2. Typography
   -------------------------------------------------------------------------- */

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--absolu-font);
    font-weight: 600;
    color: var(--absolu-text);
    line-height: 1.2;
    letter-spacing: -0.01em;
}

h1 {
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    letter-spacing: -0.02em;
}

h2 {
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    letter-spacing: -0.015em;
}

h3 {
    font-size: 1.125rem;
    font-weight: 500;
    letter-spacing: 0;
}

h4 {
    font-size: 0.9375rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

/* --------------------------------------------------------------------------
   3. Header
   -------------------------------------------------------------------------- */

.absolu-header {
    background: var(--absolu-white);
    position: relative;
    z-index: 100;
}

/* Topbar */
.absolu-header-topbar {
    background: var(--absolu-primary-dark);
    color: var(--absolu-white);
    font-family: var(--absolu-font-body);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.absolu-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 7px 0;
    flex-wrap: wrap;
}

.absolu-topbar-sep {
    margin: 0 20px;
    opacity: 0.3;
    font-size: 8px;
}

/* Main row */
.absolu-header-main {
    padding: 16px 0;
}

.absolu-header-row {
    display: grid;
    grid-template-columns: 180px 1fr auto;
    align-items: center;
    gap: 40px;
}

/* Logo */
.absolu-logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.absolu-logo img {
    max-height: 48px;
    width: auto;
}

.absolu-logo-text {
    font-family: var(--absolu-font);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--absolu-text);
    letter-spacing: -0.01em;
}

/* Search bar */
.absolu-header-search {
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}

.absolu-header-search form {
    display: flex;
    align-items: center;
    background: var(--absolu-white);
    border: 1px solid var(--absolu-border);
    padding: 0 20px;
    height: 44px;
    transition: border-color 0.2s ease;
}

.absolu-header-search form:focus-within {
    border-color: var(--absolu-text);
}

.absolu-header-search i {
    font-size: 18px;
    color: var(--absolu-text-light);
    flex-shrink: 0;
}

.absolu-header-search input[type="search"] {
    width: 100%;
    padding: 0 12px;
    font-family: var(--absolu-font-body);
    font-size: 13px;
    border: none;
    background: transparent;
    outline: none;
    color: var(--absolu-text);
    height: 100%;
}

.absolu-header-search input[type="search"]::placeholder {
    color: #aaa;
    font-weight: 300;
}

/* Hide native browser clear button */
.absolu-header-search input[type="search"]::-webkit-search-cancel-button,
.absolu-header-search input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
    display: none;
}

/* Custom clear button */
.absolu-search-clear {
    display: none;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--absolu-text-light);
    font-size: 16px;
    padding: 0;
    transition: color 0.2s ease;
}

.absolu-search-clear:hover {
    color: var(--absolu-text);
}

/* Icon group (right) */
.absolu-header-icons {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

/* Labeled icons */
.absolu-icon-labeled {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    color: var(--absolu-text);
    text-decoration: none;
    padding: 6px 10px;
    position: relative;
    transition: color 0.2s ease;
}

.absolu-icon-labeled:hover {
    color: var(--absolu-text);
}

.absolu-icon-labeled i {
    position: relative;
    color: var(--absolu-primary);
    font-size: 21px;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "Phosphor-Light" !important;
    transition: transform 0.25s ease;
}

.absolu-icon-labeled:hover i {
    transform: translateY(-2px);
}

.absolu-icon-labeled span:not(.absolu-cart-count):not(.absolu-wishlist-count) {
    font-family: var(--absolu-font);
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    white-space: nowrap;
    color: var(--absolu-text);
}

.absolu-icon-wrap {
    position: relative;
    display: inline-flex;
}

.absolu-cart-count,
.absolu-wishlist-count {
    position: absolute;
    top: -4px;
    right: -8px;
    background: none;
    color: var(--absolu-text);
    font-family: var(--absolu-font);
    font-size: 0.6rem;
    font-weight: 700;
    line-height: 1;
    display: flex;
}

/* Nav bar */
.absolu-header-nav {
    background: var(--absolu-white);
    border-bottom: 1px solid var(--absolu-border);
    position: relative;
}

.home .absolu-header-nav {
    border-bottom: none;
}

.absolu-header-nav .absolu-container {
    display: flex;
    justify-content: center;
}

.absolu-nav-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 0;
}

.absolu-nav-menu li {
    position: relative;
}

.absolu-nav-menu>li>a {
    display: block;
    padding: 14px 20px;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    transition: color 0.2s ease;
    position: relative;
}

.absolu-nav-menu>li>a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 20px;
    right: 20px;
    height: 2px;
    background: var(--absolu-primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.absolu-nav-menu>li>a:hover::after,
.absolu-nav-menu>li.current-menu-item>a::after {
    transform: scaleX(1);
}

.absolu-nav-menu>li>a:hover,
.absolu-nav-menu>li.current-menu-item>a {
    color: var(--absolu-primary);
}

.absolu-nav-menu li.absolu-nav-has-arrow>a::before {
    content: "";
    display: inline-block;
    width: 5px;
    height: 5px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    margin-left: 6px;
    margin-bottom: 2px;
    vertical-align: middle;
    float: right;
    margin-top: 6px;
}

.absolu-nav-menu li.absolu-nav-highlight>a {
    color: var(--absolu-secondary);
}

/* Mega Menu (Shop) */

.absolu-nav-shop {
    position: static;
}

.absolu-mega-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    background: var(--absolu-white);
    border: 1px solid var(--absolu-border);
    padding: 20px 28px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
    z-index: 199;
}

.absolu-nav-shop:hover .absolu-mega-menu,
.absolu-mega-menu:hover {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.absolu-mega-menu__grid {
    display: grid;
    grid-template-columns: auto auto;
    gap: 0 48px;
}

.absolu-mega-menu__col {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.absolu-mega-menu a {
    all: unset;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 700;
    color: var(--absolu-text);
    cursor: pointer;
    transition: color 0.2s ease;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
    padding: 6px 0 !important;
    display: block;
}

.absolu-mega-menu a::after {
    display: none;
}

.absolu-mega-menu a:hover {
    color: var(--absolu-primary);
}

.absolu-mega-menu__col a:hover {
    color: var(--absolu-primary);
}

/* Dropdown */
.absolu-nav-menu li ul {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--absolu-white);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
    min-width: 220px;
    padding: 8px 0;
    list-style: none;
    z-index: 200;
}

.absolu-nav-menu li:hover>ul {
    display: block;
}

.absolu-nav-menu li ul li a {
    padding: 10px 24px;
    font-size: 12px;
    text-transform: none;
    letter-spacing: 0.02em;
    font-weight: 500;
}

.absolu-nav-menu li ul li a::after {
    display: none;
}

/* --------------------------------------------------------------------------
   3a. Sticky Header
   -------------------------------------------------------------------------- */

.absolu-header.is-sticky {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: var(--absolu-white);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
    z-index: 1000;
    animation: absolu-sticky-in 0.3s ease both;
}

.admin-bar .absolu-header.is-sticky {
    top: 32px;
}

@media (max-width: 782px) {
    .admin-bar .absolu-header.is-sticky {
        top: 46px;
    }
}

@media (max-width: 600px) {
    .admin-bar .absolu-header.is-sticky {
        top: 0;
    }
}

@keyframes absolu-sticky-in {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.absolu-header.is-sticky .absolu-header-topbar {
    display: none;
}

.absolu-header.is-sticky .absolu-header-main {
    padding: 10px 0;
}

.absolu-header.is-sticky .absolu-header-row {
    grid-template-columns: auto auto 1fr auto;
    gap: 32px;
}

.absolu-header.is-sticky .absolu-logo img {
    max-height: 32px;
}

.absolu-header.is-sticky .absolu-icon-labeled span:not(.absolu-cart-count):not(.absolu-wishlist-count):not(.absolu-icon-wrap) {
    display: none;
}

.absolu-header.is-sticky .absolu-icon-labeled {
    gap: 0;
}

.absolu-header.is-sticky .absolu-header-search {
    width: 320px;
    margin-left: auto;
    margin-right: 0;
}

.absolu-header.is-sticky .absolu-header-search form {
    height: 38px;
}

.absolu-header.is-sticky .absolu-header-nav {
    display: none;
}

/* Inline sticky nav */
.absolu-sticky-nav {
    display: none;
}

.absolu-header.is-sticky .absolu-sticky-nav {
    display: flex;
    align-items: center;
    align-self: stretch;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.absolu-sticky-nav li {
    display: flex;
    align-items: center;
    align-self: stretch;
}

.absolu-sticky-nav>li>a {
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    padding: 14px 12px;
    transition: color 0.2s ease;
    white-space: nowrap;
    position: relative;
}

.absolu-sticky-nav>li>a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 12px;
    right: 12px;
    height: 2px;
    background: var(--absolu-primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.absolu-sticky-nav>li>a:hover::after,
.absolu-sticky-nav>li.current-menu-item>a::after {
    transform: scaleX(1);
}

.absolu-sticky-nav>li>a:hover,
.absolu-sticky-nav>li.current-menu-item>a {
    color: var(--absolu-primary);
}

.absolu-sticky-nav li.absolu-nav-highlight>a {
    color: var(--absolu-secondary);
}

.absolu-sticky-nav li.absolu-nav-has-arrow>a::before {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    margin-left: 6px;
    float: right;
    margin-top: 6px;
}

.absolu-sticky-nav li.absolu-nav-shop {
    position: static;
}

.absolu-sticky-nav .absolu-mega-menu a {
    padding: 0;
}

.absolu-sticky-nav .absolu-mega-menu {
    top: calc(100% + 10px);
    left: auto;
    right: auto;
    transform: translateX(0) translateY(-4px);
}

.absolu-sticky-nav .absolu-nav-shop:hover .absolu-mega-menu,
.absolu-sticky-nav .absolu-mega-menu:hover {
    transform: translateX(0) translateY(0);
}

/* --------------------------------------------------------------------------
   3b. Mobile Toggle + Mobile Search
   -------------------------------------------------------------------------- */

.absolu-mobile-toggle {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    z-index: 110;
    flex-shrink: 0;
}

.absolu-mobile-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--absolu-text);
    transition: all 0.3s ease;
}

.absolu-mobile-toggle span + span {
    margin-top: 5px;
}

.absolu-mobile-toggle.is-active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.absolu-mobile-toggle.is-active span:nth-child(2) {
    opacity: 0;
}

.absolu-mobile-toggle.is-active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile search toggle icon (hidden on desktop) */
.absolu-mobile-search-toggle {
    display: none;
}

/* Mobile expandable search bar (hidden on desktop) */
.absolu-mobile-search {
    display: none;
}

/* --------------------------------------------------------------------------
   3c. Mobile Nav
   -------------------------------------------------------------------------- */

.absolu-mobile-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.absolu-mobile-overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.absolu-mobile-nav {
    display: none;
    position: fixed;
    top: 0;
    left: -100%;
    width: 300px;
    height: 100vh;
    height: 100dvh;
    background: var(--absolu-white);
    z-index: 1001;
    transition: left 0.3s ease;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.absolu-mobile-nav.is-open {
    left: 0;
}

.absolu-mobile-nav-header {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 12px 16px;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-mobile-nav-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--absolu-text);
    font-size: 20px;
    padding: 0;
}

.absolu-mobile-nav-inner {
    padding: 16px 24px 24px;
}

.absolu-mobile-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-mobile-menu__item {
    position: relative;
}

.absolu-mobile-menu__item.has-children > a {
    padding-right: 48px;
}

.absolu-mobile-menu__toggle {
    position: absolute;
    right: 0;
    top: 0;
    width: 44px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    border-left: 1px solid var(--absolu-border);
    cursor: pointer;
    color: var(--absolu-text-light);
    transition: transform 0.3s ease;
}

.absolu-mobile-menu__toggle i {
    font-size: 16px;
    transition: transform 0.3s ease;
}

.absolu-mobile-menu__item.is-open .absolu-mobile-menu__toggle i {
    transform: rotate(180deg);
}

.absolu-mobile-submenu {
    list-style: none;
    padding: 0 0 8px 16px;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.absolu-mobile-menu__item.is-open .absolu-mobile-submenu {
    max-height: 400px;
}

.absolu-mobile-submenu li a {
    display: block;
    padding: 10px 0;
    font-family: var(--absolu-font);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-mobile-submenu li a:hover {
    color: var(--absolu-primary);
}

.absolu-mobile-menu li a {
    display: block;
    padding: 14px 0;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-mobile-nav-links {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--absolu-border);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.absolu-mobile-nav-links a {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
}

.absolu-mobile-nav-links a i {
    font-size: 18px;
}

body.mobile-nav-open {
    overflow: hidden;
}


/* --------------------------------------------------------------------------
   4. Footer
   -------------------------------------------------------------------------- */

.absolu-footer {
    margin-top: 0;
}

/* Newsletter band */
.absolu-footer-newsletter {
    background: var(--absolu-bg-light);
    padding: 48px 0;
    border-top: 1px solid var(--absolu-border);
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-footer-newsletter__inner {
    display: grid;
    grid-template-columns: 1fr 1px 1fr;
    gap: 0;
    align-items: center;
}

.absolu-footer-newsletter__inner::before {
    content: "";
    display: block;
    width: 1px;
    height: 60px;
    background: var(--absolu-border);
    justify-self: center;
    order: 2;
}

.absolu-footer-newsletter__left {
    order: 1;
    padding-right: 60px;
}

.absolu-footer-newsletter__right {
    order: 3;
    padding-left: 60px;
}

.absolu-footer-newsletter__left h3,
.absolu-footer-newsletter__right h3 {
    font-family: var(--absolu-font);
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--absolu-text);
    margin: 0 0 16px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.absolu-newsletter-form {
    max-width: 440px;
}

.absolu-newsletter-field {
    display: flex;
    gap: 0;
}

.absolu-newsletter-field input[type="email"] {
    flex: 1;
    background: var(--absolu-white);
    border: 1px solid var(--absolu-border);
    border-right: none;
    border-radius: 0;
    padding: 13px 16px;
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    color: var(--absolu-text);
    outline: none;
    transition: border-color 0.2s ease;
}

.absolu-newsletter-field input[type="email"]:focus {
    border-color: var(--absolu-text);
}

.absolu-newsletter-field input::placeholder {
    color: #aaa;
}

.absolu-newsletter-field button {
    background: var(--absolu-primary);
    border: 1px solid var(--absolu-primary);
    color: var(--absolu-white);
    font-size: 1rem;
    padding: 0 18px;
    cursor: pointer;
    transition: background 0.2s ease;
    display: flex;
    align-items: center;
}

.absolu-newsletter-field button:hover {
    background: var(--absolu-primary-dark);
    border-color: var(--absolu-primary-dark);
}

.absolu-newsletter-msg {
    font-size: 0.75rem;
    margin-top: 8px;
    min-height: 18px;
}

.absolu-newsletter-msg.is-success {
    color: var(--absolu-success);
}

.absolu-newsletter-msg.is-error {
    color: var(--absolu-error);
}

/* Newsletter socials */
.absolu-footer-newsletter__socials {
    display: flex;
    gap: 18px;
    align-items: center;
}

.absolu-footer-newsletter__socials a {
    color: var(--absolu-text);
    font-size: 1.6rem;
    transition: color 0.2s ease;
    line-height: 1;
}

.absolu-footer-newsletter__socials a:hover {
    color: var(--absolu-primary);
}

/* Footer main */
.absolu-footer-main {
    background: var(--absolu-text);
    color: #cccccc;
    padding: 60px 0;
}

.absolu-footer-grid {
    display: grid;
    grid-template-columns: 1.8fr 1fr 1fr 1fr;
    gap: 60px;
}

.absolu-footer-logo {
    max-height: 36px;
    width: auto;
    margin-bottom: 20px;
    filter: brightness(10);
}

.absolu-footer-main p {
    font-size: 0.875rem;
    line-height: 1.8;
    color: var(--absolu-strike);
    max-width: 320px;
}

.absolu-footer-contact {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.absolu-footer-contact a {
    font-size: 0.8125rem;
    color: var(--absolu-strike);
    transition: color 0.2s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.absolu-footer-contact a i {
    font-size: 16px;
}

.absolu-footer-contact a:hover {
    color: var(--absolu-white);
}

.absolu-footer-socials {
    display: flex;
    gap: 20px;
    margin-top: 28px;
}

.absolu-footer-socials a {
    color: #999;
    transition: color 0.2s ease;
}

.absolu-footer-socials a:hover {
    color: var(--absolu-white);
}

.absolu-footer-socials a i {
    font-size: 20px;
}

.absolu-footer-main h4 {
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 24px;
}

.absolu-footer-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-footer-menu li a {
    display: block;
    padding: 7px 0;
    font-size: 0.875rem;
    color: var(--absolu-strike);
    transition: color 0.2s ease;
}

.absolu-footer-menu li a:hover {
    color: var(--absolu-white);
}

/* Footer bottom */
.absolu-footer-bottom {
    background: var(--absolu-text);
    padding: 24px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.absolu-footer-bottom__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.absolu-footer-bottom p {
    margin: 0;
    font-size: 0.75rem;
    color: #999;
    letter-spacing: 0.02em;
}

.absolu-footer-bottom p a {
    color: #999;
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-footer-bottom p a:hover {
    color: var(--absolu-white);
}

.absolu-footer-payments {
    display: flex;
    gap: 8px;
}

.absolu-footer-payments span {
    font-family: var(--absolu-font);
    font-size: 0.5625rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #999;
    padding: 5px 0;
    border: 1px solid rgba(255, 255, 255, 0.08);
    width: 68px;
    text-align: center;
}

/* Trustpilot column */
.absolu-trustpilot-link {
    display: block;
    margin-bottom: 16px;
}

.absolu-trustpilot-logo {
    width: 100%;
    max-width: 180px;
    height: auto;
    display: block;
}

.absolu-trustpilot-desc {
    font-size: 0.8125rem;
    color: #aaa;
    line-height: 1.6;
    margin-bottom: 16px;
}

.absolu-trustpilot-cta {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #aaa;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: color 0.2s ease;
}

.absolu-trustpilot-cta:hover {
    color: var(--absolu-white);
}

.absolu-trustpilot-cta i {
    font-size: 12px;
    transition: transform 0.2s ease;
}

.absolu-trustpilot-cta:hover i {
    transform: translateX(3px);
}

/* Floating WhatsApp */
.absolu-whatsapp-float {
    position: fixed;
    bottom: 28px;
    right: 28px;
    width: 56px;
    height: 56px;
    background: #25D366;
    color: var(--absolu-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 99;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    text-decoration: none;
}

.absolu-whatsapp-float i {
    font-size: 28px;
}

.absolu-whatsapp-float:hover {
    transform: scale(1.08);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.2);
    color: var(--absolu-white);
}

/* --------------------------------------------------------------------------
   5. Buttons (Global)
   -------------------------------------------------------------------------- */

.wp-element-button,
.wp-block-button__link,
button[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
    font-family: var(--absolu-font);
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background-color: var(--absolu-primary);
    color: var(--absolu-white);
    border: none;
    border-radius: 2px;
    padding: 12px 28px;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.wp-element-button:hover,
.wp-block-button__link:hover,
button[type="submit"]:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce .button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background-color: var(--absolu-primary-dark);
    color: var(--absolu-white);
}

/* --------------------------------------------------------------------------
   6. Forms
   -------------------------------------------------------------------------- */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
textarea,
select {
    font-family: var(--absolu-font-body);
    font-size: 0.9rem;
    border: 1px solid var(--absolu-border);
    border-radius: 2px;
    padding: 10px 14px;
    outline: none;
    transition: border-color 0.2s ease;
}

input:focus,
textarea:focus,
select:focus {
    border-color: var(--absolu-text);
}

/* --------------------------------------------------------------------------
   7. WooCommerce - Product Cards
   -------------------------------------------------------------------------- */

.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 20px;
    list-style: none;
    padding: 0;
}

.woocommerce ul.products li.product {
    text-align: left;
    margin: 0;
    padding: 0;
    width: auto;
    float: none;
    position: relative;
    background: var(--absolu-white);
    overflow: hidden;
}

/* Product image */
.woocommerce ul.products li.product a img {
    border-radius: 0;
    transition: transform 0.4s ease;
    display: block;
    width: 100%;
}

.woocommerce ul.products li.product:hover a img {
    transform: scale(1.03);
}

/* Product info */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--absolu-font-body);
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--absolu-text);
    padding: 12px 12px 4px;
    margin: 0;
    line-height: 1.4;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Price */
.woocommerce ul.products li.product .price {
    color: var(--absolu-text);
    font-family: var(--absolu-font);
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0 12px 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.woocommerce ul.products li.product .price del {
    color: #aaa;
    font-weight: 400;
    font-size: 0.78rem;
    text-decoration: line-through;
}

.woocommerce ul.products li.product .price ins {
    color: var(--absolu-text);
    font-weight: 700;
    text-decoration: none;
    font-size: 0.95rem;
}

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--absolu-primary);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 11px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 2px;
    line-height: 1.4;
    min-width: auto;
    min-height: auto;
    margin: 0;
    z-index: 5;
}

/* Wishlist button (from YITH or similar plugin) */
.woocommerce ul.products li.product .yith-wcwl-add-to-wishlist,
.woocommerce ul.products li.product .tinvwl_add_to_wishlist_button,
.woocommerce ul.products li.product .wishlist-button {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 5;
}

/* Add to cart button */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product a.button {
    display: block;
    width: 100%;
    background: var(--absolu-primary);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 12px 16px;
    border: none;
    border-radius: 0;
    margin: 0;
    transition: background-color 0.2s ease;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover,
.woocommerce ul.products li.product a.button:hover {
    background: var(--absolu-primary-dark);
    color: var(--absolu-white);
}

/* --------------------------------------------------------------------------
   8. WooCommerce - Single Product
   -------------------------------------------------------------------------- */

.single-product .product .product_title {
    font-size: 1.6rem;
    font-weight: 600;
}

.single-product .product .price {
    font-size: 1.4rem;
    color: var(--absolu-text);
    font-weight: 600;
}

.single-product .product .price ins {
    color: var(--absolu-primary);
    text-decoration: none;
}

.single-product .product .single_add_to_cart_button {
    width: 100%;
    padding: 14px 30px;
    font-size: 0.85rem;
}

/* --------------------------------------------------------------------------
   9. WooCommerce - Cart & Checkout
   -------------------------------------------------------------------------- */

/* Cart and checkout containers handled by page templates */

/* --------------------------------------------------------------------------
   10. Site Content (override Hello Elementor constraints)
   -------------------------------------------------------------------------- */

.site-main {
    max-width: var(--absolu-container);
    margin: 0 auto;
    padding-inline: var(--absolu-gap);
}

.absolu-site-content {
    padding: 0;
}

.home .site-main {
    padding: 0;
    max-width: none;
}

.home .entry-title,
.home .page-header,
.home .entry-header {
    display: none;
}

/* Hero banner */
.absolu-hero-wrap {
    width: 100%;
    height: clamp(220px, 30vw, 420px);
    overflow: hidden;
}

.absolu-hero-banner {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center center;
}

/* --------------------------------------------------------------------------
   10b. Homepage Sections
   -------------------------------------------------------------------------- */

.absolu-section {
    padding: 50px 0;
}

.absolu-new-arrivals {
    padding-top: 100px;
}

/* Section header: eyebrow label + large title */
.absolu-section-header {
    margin-bottom: clamp(32px, 5vw, 60px);
}

.absolu-section-header--center {
    text-align: center;
}

.absolu-section-eyebrow {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--absolu-primary);
    margin-bottom: 18px;
}

.absolu-section-title {
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--absolu-text);
    margin: 0;
    line-height: 1.1;
}

/* New Arrivals product grid */
.absolu-product-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 32px 24px;
}

.absolu-product-card {
    background: var(--absolu-white);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    position: relative;
    border: 1px solid transparent;
    transition: border-color 0.3s ease;
}

.absolu-product-card:hover {
    border-color: var(--absolu-border);
}

.absolu-product-card__wishlist {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 6;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: var(--absolu-text);
    font-size: 1.25rem;
    line-height: 1;
    transition: color 0.2s ease, transform 0.3s ease;
}

.absolu-product-card__wishlist:hover {
    color: var(--absolu-primary);
}

.absolu-product-card__wishlist.is-active {
    color: var(--absolu-primary);
    animation: absoluHeartPop 0.35s ease;
}

.absolu-product-card__wishlist.is-active i {
    font-family: "Phosphor-Fill" !important;
}

@keyframes absoluHeartPop {
    0% {
        transform: scale(1);
    }

    30% {
        transform: scale(1.3);
    }

    60% {
        transform: scale(0.9);
    }

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

.absolu-product-card__link {
    display: flex;
    flex-direction: column;
    flex: 1;
    color: inherit;
    text-decoration: none;
}

.absolu-product-card__image {
    position: relative;
    overflow: hidden;
    background: var(--absolu-bg-light);
}

.absolu-product-card__image img {
    width: 100%;
    display: block;
}

.absolu-product-card__hover-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 0.5s ease;
}

.absolu-product-card:hover .absolu-product-card__hover-img {
    opacity: 1;
}

.absolu-product-card__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: var(--absolu-white);
    color: #16a34a;
    font-family: var(--absolu-font-body);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: normal;
    padding: 4px 10px;
    line-height: 1;
    border: 1px solid var(--absolu-border);
    z-index: 5;
}

.absolu-product-card__info {
    padding: 20px 8px 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    text-align: center;
}

.absolu-product-card__brand {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    margin: 0 0 8px;
    display: block;
}

.absolu-product-card__title {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    font-weight: 300;
    color: var(--absolu-text-light);
    margin: 0 0 12px;
    line-height: 1.5;
}

.absolu-product-card:hover .absolu-product-card__title {
    color: var(--absolu-text);
}

.absolu-product-card__price {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    font-weight: 400;
    color: var(--absolu-text);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: auto;
    padding-bottom: 20px;
}

.absolu-product-card__price del {
    color: var(--absolu-strike);
    font-weight: 300;
    font-size: 0.8rem;
}

.absolu-product-card__price ins {
    color: var(--absolu-primary);
    font-weight: 400;
    text-decoration: none;
}

.absolu-product-card__price--oos {
    color: var(--absolu-primary);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.absolu-product-card__atc {
    display: block;
    width: fit-content;
    margin: 0 auto;
    background: none;
    color: var(--absolu-text);
    font-family: var(--absolu-font);
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.05em;
    text-transform: none;
    padding: 0 0 16px;
    text-align: center;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    opacity: 0;
    transition: opacity 0.3s ease, color 0.2s ease;
}

.absolu-product-card__atc.loading {
    pointer-events: none;
    opacity: 0.5;
}

.absolu-product-card__atc.atc-added {
    color: var(--absolu-secondary);
    text-decoration: none;
    pointer-events: none;
}

.absolu-product-card:hover .absolu-product-card__atc {
    opacity: 1;
}

@media (hover: none), (pointer: coarse) {
    .absolu-product-card__atc {
        opacity: 1;
    }
}

.absolu-product-card__atc:hover {
    color: var(--absolu-primary);
}

.absolu-product-card .added_to_cart {
    display: none;
}

/* Section CTA */
.absolu-section-cta {
    text-align: center;
    margin-top: 40px;
}

.absolu-btn--outline {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text);
    border: 1px solid var(--absolu-text);
    background: transparent;
    padding: 14px 32px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.absolu-btn--outline:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
    border-color: var(--absolu-text);
}

/* Shop by Category */
.absolu-gender {
    padding: 50px 0;
}

.absolu-gender-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    height: 392px;
}

.absolu-gender-card {
    position: relative;
    display: block;
    overflow: hidden;
    text-decoration: none;
    color: var(--absolu-white);
}


.absolu-gender-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center top;
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.absolu-gender-card:hover .absolu-gender-card__bg {
    transform: scale(1.03);
}

.absolu-gender-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
            rgba(0, 0, 0, 0.55) 0%,
            rgba(0, 0, 0, 0.15) 40%,
            rgba(0, 0, 0, 0.05) 100%);
    transition: background 0.4s ease;
}

.absolu-gender-card:hover .absolu-gender-card__overlay {
    background: linear-gradient(to top,
            rgba(0, 0, 0, 0.6) 0%,
            rgba(0, 0, 0, 0.2) 40%,
            rgba(0, 0, 0, 0.08) 100%);
}

.absolu-gender-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 48px 40px;
    z-index: 2;
}

.absolu-gender-card__subtitle {
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 12px;
    display: block;
}

.absolu-gender-card__title {
    font-family: var(--absolu-font);
    font-size: 1.75rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-white);
    margin: 0 0 20px;
    line-height: 1;
}


.absolu-gender-card__cta {
    font-family: var(--absolu-font);
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--absolu-white);
    display: inline-flex;
    align-items: center;
    gap: 10px;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.absolu-gender-card__cta::after {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--absolu-white);
    display: block;
    transition: width 0.3s ease;
}

.absolu-gender-card:hover .absolu-gender-card__cta {
    opacity: 1;
    transform: translateY(0);
}

@media (hover: none), (pointer: coarse) {
    .absolu-gender-card__cta {
        opacity: 1;
        transform: translateY(0);
    }
}

.absolu-gender-card:hover .absolu-gender-card__cta::after {
    width: 40px;
}

.absolu-gender-card__cta i {
    display: none;
}

/* Brands We Stock */
.absolu-brands {
    padding: 50px 0;
    overflow: hidden;
}


.absolu-brands-marquee {
    width: 100%;
    overflow: hidden;
    mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}

.absolu-brands-track {
    display: flex;
    align-items: center;
    width: max-content;
    animation: absolu-marquee 80s linear infinite;
}

.absolu-brands-track:hover {
    animation-play-state: paused;
}

.absolu-brands-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    flex-shrink: 0;
    padding: 12px 36px 0;
}

.absolu-brands-item img {
    height: 72px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
    display: block;
    filter: grayscale(100%);
    transition: transform 0.3s ease, filter 0.3s ease;
}

.absolu-brands-item:hover img {
    filter: grayscale(0%);
}

.absolu-brands-name {
    font-family: var(--absolu-font);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    margin-top: 8px;
    white-space: nowrap;
}

.absolu-brands-item:hover img {
    transform: translateY(-6px);
}

.absolu-brands-item:hover .absolu-brands-name {
    opacity: 1;
    transform: translateY(0);
}

@keyframes absolu-marquee {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .absolu-brands {
        padding: 30px 0;
    }

    .absolu-brands-item {
        padding: 0 36px;
    }

    .absolu-brands-item img {
        height: 52px;
    }

    .absolu-brands-track {
        animation-duration: 55s;
    }

    .absolu-brands-name {
        display: none;
    }
}

@media (max-width: 480px) {
    .absolu-brands-item {
        padding: 0 24px;
    }

    .absolu-brands-item img {
        height: 40px;
        max-width: 120px;
    }

    .absolu-brands-track {
        animation-duration: 45s;
    }
}

/* Brands Directory Page */
.absolu-page--brands {
    padding-bottom: 0;
}

.absolu-brands-search {
    max-width: 480px;
    margin: 0 auto 40px;
    position: relative;
}

.absolu-brands-search__icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: var(--absolu-text-light);
    pointer-events: none;
}

.absolu-brands-search .absolu-brands-search__input {
    width: 100%;
    padding: 14px 20px 14px 48px;
    border: 1px solid var(--absolu-border);
    border-radius: 0;
    font-family: var(--absolu-font-body);
    font-size: 15px;
    color: var(--absolu-text);
    background: var(--absolu-white);
    transition: border-color 0.2s ease;
}

.absolu-brands-search .absolu-brands-search__input:focus {
    outline: none;
    border-color: var(--absolu-text);
}

.absolu-brands-search .absolu-brands-search__input::placeholder {
    color: #999;
}

.absolu-brands-alpha {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px;
    margin-bottom: 48px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-brands-alpha__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-decoration: none;
    color: var(--absolu-text);
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

.absolu-brands-alpha__link:hover {
    color: var(--absolu-primary);
    border-color: var(--absolu-primary);
}

.absolu-brands-alpha__link.is-disabled {
    display: none;
}

.absolu-brands-group {
    margin-bottom: 48px;
}

.absolu-brands-group__letter {
    font-family: var(--absolu-font);
    font-size: 28px;
    font-weight: 500;
    color: var(--absolu-primary);
    letter-spacing: 0.06em;
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--absolu-primary);
    display: inline-block;
}

.absolu-brands-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}

.absolu-brands-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    text-decoration: none;
    padding: 24px 12px 20px;
    border: 1px solid var(--absolu-border);
    background: var(--absolu-white);
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.absolu-brands-card:hover {
    border-color: var(--absolu-primary);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.absolu-brands-card__logo {
    width: 100%;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
}

.absolu-brands-card__logo img {
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
    filter: grayscale(100%);
    transition: filter 0.3s ease;
}

.absolu-brands-card:hover .absolu-brands-card__logo img {
    filter: grayscale(0%);
}

.absolu-brands-card__initial {
    font-family: var(--absolu-font);
    font-size: 32px;
    font-weight: 500;
    color: var(--absolu-text-light);
}

.absolu-brands-card__name {
    font-family: var(--absolu-font);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    line-height: 1.3;
}

.absolu-brands-card__count {
    font-family: var(--absolu-font-body);
    font-size: 12px;
    color: var(--absolu-text-light);
    margin-top: 4px;
}

.absolu-brands-empty {
    text-align: center;
    font-family: var(--absolu-font-body);
    font-size: 15px;
    color: var(--absolu-text-light);
    padding: 60px 0;
}

@media (max-width: 1024px) {
    .absolu-brands-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 768px) {
    .absolu-page--brands {
        padding-bottom: 0;
    }

    .absolu-page--brands .absolu-archive-header {
        padding: 4px 0 24px;
    }

    .absolu-page--brands .absolu-archive-header__title {
        font-size: 26px;
    }

    .absolu-page--brands .absolu-archive-header__desc {
        font-size: 0.8rem;
        margin-top: 12px;
    }

    .absolu-brands-search {
        margin-bottom: 24px;
    }

    .absolu-brands-alpha {
        gap: 2px;
        margin-bottom: 24px;
        padding-bottom: 12px;
    }

    .absolu-brands-alpha__link {
        min-width: 36px;
        min-height: 36px;
        width: 36px;
        height: 36px;
        font-size: 11px;
    }

    .absolu-brands-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 10px;
    }

    .absolu-brands-card {
        padding: 16px 8px 14px;
    }

    .absolu-brands-card__logo {
        height: 56px;
        margin-bottom: 10px;
    }

    .absolu-brands-card__name {
        font-size: 11px;
    }

    .absolu-brands-card__count {
        font-size: 11px;
    }

    .absolu-brands-group {
        margin-bottom: 28px;
    }

    .absolu-brands-group__letter {
        font-size: 20px;
        margin-bottom: 14px;
        padding-bottom: 8px;
    }

    .absolu-brands-empty {
        padding: 40px 0;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .absolu-brands-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .absolu-brands-search .absolu-brands-search__input {
        padding: 12px 16px 12px 42px;
        font-size: 14px;
    }

    .absolu-brands-search__icon {
        left: 14px;
        font-size: 16px;
    }

    .absolu-brands-alpha__link {
        min-width: 32px;
        min-height: 32px;
        width: 32px;
        height: 32px;
        font-size: 11px;
    }
}

/* The Absolu Difference */
.absolu-difference {
    background: var(--absolu-white);
    padding: 50px 0 100px;
}

.absolu-difference-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 60px;
}

.absolu-difference-item {
    text-align: center;
    padding: 0;
}

.absolu-difference-icon {
    width: clamp(64px, 8vw, 100px);
    height: clamp(64px, 8vw, 100px);
    margin: 0 auto 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.absolu-difference-icon img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.absolu-difference-item h4 {
    font-family: var(--absolu-font);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0 0 10px;
    color: var(--absolu-text);
}

.absolu-difference-item p {
    font-size: 0.85rem;
    color: var(--absolu-text-light);
    margin: 0;
    line-height: 1.7;
    max-width: 200px;
    margin: 0 auto;
}

/* --------------------------------------------------------------------------
   11. Responsive
   -------------------------------------------------------------------------- */

@media (max-width: 1024px) {
    .absolu-footer-newsletter__inner {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .absolu-footer-newsletter__inner::before {
        width: 100%;
        height: 1px;
    }

    .absolu-footer-newsletter__left {
        padding-right: 0;
    }

    .absolu-footer-newsletter__right {
        padding-left: 0;
    }

    .absolu-newsletter-form {
        max-width: 100%;
    }

    .absolu-footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(4, 1fr);
    }

    .absolu-product-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Tablet (1024px): Switch to mobile header layout
   -------------------------------------------------------------------------- */

@media (max-width: 1024px) {

    /* Topbar */
    .absolu-topbar-inner {
        font-size: 11px;
        padding: 5px 0;
    }

    .absolu-topbar-sep {
        margin: 0 12px;
    }

    /* Header main: single compact row */
    .absolu-header-main {
        padding: 0;
    }

    .absolu-header-row {
        display: flex;
        align-items: center;
        gap: 0;
        height: 52px;
        padding: 0;
    }

    .absolu-header-row .absolu-sticky-nav {
        display: none !important;
    }

    /* Hamburger: left side */
    .absolu-mobile-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        order: 1;
        padding: 8px;
        margin-left: -8px;
    }

    /* Logo: centered via flex */
    .absolu-logo {
        order: 2;
        flex: 1;
        display: flex;
        justify-content: center;
        margin: 0;
    }

    .absolu-logo img {
        max-height: 32px;
    }

    /* Desktop search: hidden on mobile */
    .absolu-header-search {
        display: none;
    }

    /* Icons: right side, tight */
    .absolu-header-icons {
        order: 3;
        margin-left: 0;
        gap: 0;
        flex-shrink: 0;
    }

    .absolu-icon-labeled span:not(.absolu-cart-count):not(.absolu-wishlist-count):not(.absolu-icon-wrap) {
        display: none;
    }

    .absolu-icon-labeled {
        gap: 0;
        padding: 6px;
    }

    .absolu-icon-labeled i {
        font-size: 20px;
    }

    /* Show mobile search icon */
    .absolu-mobile-search-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        padding: 6px;
        color: var(--absolu-primary);
    }

    .absolu-mobile-search-toggle i {
        font-size: 20px;
        font-family: "Phosphor-Light" !important;
        line-height: 1;
    }

    /* Mobile expandable search bar */
    .absolu-mobile-search {
        display: block;
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.3s ease, padding 0.3s ease;
        padding: 0;
        border-top: 1px solid transparent;
    }

    .absolu-mobile-search.is-open {
        max-height: 60px;
        padding: 8px 0;
        border-top-color: var(--absolu-border);
    }

    .absolu-mobile-search form {
        display: flex;
        align-items: center;
        background: #f5f5f5;
        border-radius: 0;
        height: 40px;
        padding: 0 12px;
        gap: 8px;
    }

    .absolu-mobile-search i {
        font-size: 18px;
        color: var(--absolu-text-light);
        flex-shrink: 0;
    }

    .absolu-mobile-search input[type="search"] {
        flex: 1;
        border: none;
        background: transparent;
        outline: none;
        font-family: var(--absolu-font-body);
        font-size: 14px;
        color: var(--absolu-text);
        padding: 0;
        height: 100%;
    }

    .absolu-mobile-search input[type="search"]::placeholder {
        color: #999;
        font-weight: 300;
    }

    .absolu-mobile-search input[type="search"]::-webkit-search-cancel-button,
    .absolu-mobile-search input[type="search"]::-webkit-search-decoration {
        -webkit-appearance: none;
        appearance: none;
        display: none;
    }

    .absolu-mobile-search-close {
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        padding: 8px;
        min-width: 36px;
        min-height: 36px;
        color: var(--absolu-text-light);
        font-size: 16px;
    }

    /* Hide desktop nav */
    .absolu-header-nav {
        display: none;
    }

    /* Enable mobile nav + overlay */
    .absolu-mobile-nav {
        display: block;
    }

    .absolu-mobile-overlay {
        display: block;
    }

    /* --- Sticky header on mobile/tablet --- */
    .absolu-header.is-sticky .absolu-header-row {
        display: flex;
        height: 48px;
    }

    .absolu-header.is-sticky .absolu-header-search {
        display: none;
    }

    .absolu-header.is-sticky .absolu-sticky-nav {
        display: none !important;
    }

    .absolu-header.is-sticky .absolu-logo img {
        max-height: 28px;
    }
}

/* --------------------------------------------------------------------------
   Mobile (768px): Tighter topbar, smaller elements
   -------------------------------------------------------------------------- */

@media (max-width: 768px) {

    /* Topbar: hide last message */
    .absolu-header-topbar .absolu-topbar-sep:last-of-type,
    .absolu-header-topbar span:last-child {
        display: none;
    }

    .absolu-header-row {
        height: 48px;
    }

    .absolu-logo img {
        max-height: 28px;
    }

    .absolu-icon-labeled {
        padding: 8px;
        min-width: 36px;
        min-height: 36px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .absolu-icon-labeled i {
        font-size: 19px;
    }

    /* Sections */
    .absolu-section {
        padding: 30px 0;
    }

    .absolu-new-arrivals {
        padding-top: 60px;
    }

    .absolu-gender {
        padding: 30px 0;
    }

    .absolu-difference {
        padding: 30px 0 60px;
    }

    .absolu-gender-grid {
        grid-template-columns: 1fr;
        height: auto;
    }

    .absolu-gender-card {
        height: 280px;
    }

    .absolu-gender-card__title {
        font-size: 1.5rem;
    }

    .absolu-gender-card__content {
        padding: 28px 24px;
    }

    .absolu-gender-card__cta {
        opacity: 1;
        transform: translateY(0);
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }

    .absolu-product-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }

    .absolu-difference-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .absolu-footer-newsletter {
        padding: 36px 0;
    }

    .absolu-footer-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .absolu-footer-bottom__inner {
        flex-direction: column;
        gap: 12px;
    }

    .absolu-footer-payments {
        flex-wrap: wrap;
        justify-content: center;
    }

    h1 {
        font-size: 1.5rem;
    }

    h2 {
        font-size: 1.25rem;
    }
}

/* --------------------------------------------------------------------------
   Small mobile (480px)
   -------------------------------------------------------------------------- */

@media (max-width: 480px) {

    /* Topbar: single message */
    .absolu-topbar-inner span:not(:first-child) {
        display: none;
    }

    .absolu-topbar-inner {
        justify-content: center;
    }

    .absolu-mobile-nav {
        width: 280px;
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .absolu-product-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .absolu-difference-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__title {
        font-size: 0.8rem;
    }

    .woocommerce ul.products li.product .price {
        font-size: 0.8rem;
    }
}

/* --------------------------------------------------------------------------
   12. Animations
   -------------------------------------------------------------------------- */

/* Fade up on scroll (applied via JS IntersectionObserver) */
.absolu-animate {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.absolu-animate.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger children - delay is set dynamically via JS for grids */

/* Fade in (no movement) */
.absolu-fade {
    opacity: 0;
    transition: opacity 0.6s ease;
}

.absolu-fade.is-visible {
    opacity: 1;
}

/* Slide up from bottom */
@keyframes absolu-slide-up {
    from {
        opacity: 0;
        transform: translateY(32px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Page load entrance */
.absolu-header {
    animation: absolu-fade-in 0.4s ease;
}

@keyframes absolu-fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* Smooth global transitions */
a,
button,
input,
.absolu-icon-labeled,
.absolu-nav-menu li a {
    transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

/* Product card entrance on scroll */
.woocommerce ul.products li.product {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.woocommerce ul.products li.product.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* --------------------------------------------------------------------------
   13. Inner Pages (shared)
   -------------------------------------------------------------------------- */

.absolu-page {
    padding: 60px 0;
}

.absolu-container--narrow {
    max-width: 840px;
}

/* Breadcrumbs */
.absolu-breadcrumbs {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    margin-bottom: 32px;
    padding: 8px 0;
}

.absolu-breadcrumbs a {
    color: var(--absolu-text-light);
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-breadcrumbs a:hover {
    color: var(--absolu-primary);
}

.absolu-breadcrumb__sep {
    margin: 0 8px;
    opacity: 0.4;
}

.absolu-breadcrumbs span:last-child {
    color: var(--absolu-text);
}

/* Page headers */
.absolu-page-header {
    margin-bottom: 48px;
}

.absolu-page-title {
    font-family: var(--absolu-font);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--absolu-text);
    margin: 0 0 12px;
    line-height: 1.1;
}

.absolu-page-desc {
    font-size: 1rem;
    color: var(--absolu-text-light);
    line-height: 1.7;
    margin: 0;
    max-width: 560px;
}

/* Page content (policies, about etc) */
.absolu-page-content {
    font-size: 1rem;
    line-height: 1.8;
    color: var(--absolu-text);
}

.absolu-page-content h2 {
    font-size: 1.25rem;
    margin: 48px 0 16px;
}

.absolu-page-content h3 {
    font-size: 1rem;
    margin: 32px 0 12px;
}

.absolu-page-content p {
    margin: 0 0 20px;
    color: var(--absolu-text-light);
}

.absolu-page-content ul,
.absolu-page-content ol {
    margin: 0 0 20px;
    padding-left: 24px;
    color: var(--absolu-text-light);
}

.absolu-page-content li {
    margin-bottom: 8px;
}

.absolu-page-content a {
    color: var(--absolu-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* Contact Page */
.absolu-contact-intro {
    max-width: 600px;
    margin-bottom: 64px;
    font-size: 1.0625rem;
    color: var(--absolu-text-light);
    line-height: 1.8;
}

.absolu-contact-channels {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-bottom: 80px;
}

.absolu-contact-card {
    padding: 48px 32px;
    text-align: center;
    text-decoration: none;
    color: var(--absolu-text);
    transition: background 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
}

a.absolu-contact-card {
    text-decoration: none;
    color: var(--absolu-text);
}

a.absolu-contact-card:hover {
    color: var(--absolu-text);
}

.absolu-contact-card:hover {
    background: var(--absolu-bg-light);
}

.absolu-contact-card i {
    font-size: 32px;
    color: var(--absolu-primary);
    margin-bottom: 20px;
    display: block;
}

.absolu-contact-card strong {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 10px;
    text-decoration: none;
}

.absolu-contact-card span {
    font-size: 0.875rem;
    color: var(--absolu-text-light);
    line-height: 1.6;
    text-decoration: none;
}

.absolu-contact-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    margin-bottom: 80px;
    min-height: 560px;
}

.absolu-contact-form-side {
    padding: 60px;
    background: var(--absolu-bg-light);
}

.absolu-contact-form-side h2 {
    font-family: var(--absolu-font);
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    margin: 0 0 8px;
}

.absolu-contact-form-side>p {
    font-size: 0.875rem;
    color: var(--absolu-text-light);
    margin: 0 0 36px;
}

.absolu-contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.absolu-contact-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.absolu-contact-form label {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 6px;
}

.absolu-contact-form input,
.absolu-contact-form textarea {
    width: 100%;
    padding: 13px 16px;
    border: 1px solid var(--absolu-border);
    background: var(--absolu-white);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    outline: none;
    transition: border-color 0.2s ease;
    border-radius: 0;
}

.absolu-contact-form input:focus,
.absolu-contact-form textarea:focus {
    border-color: var(--absolu-text);
}

.absolu-contact-form textarea {
    min-height: 120px;
    resize: vertical;
}

.absolu-contact-form button {
    align-self: flex-start;
    background: var(--absolu-text);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: none;
    padding: 16px 48px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.absolu-contact-form button:hover {
    background: var(--absolu-primary);
}

.absolu-contact-form button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.absolu-form-msg {
    font-size: 0.8125rem;
    margin-top: 12px;
    min-height: 20px;
}

.absolu-form-msg.is-success {
    color: var(--absolu-success);
}

.absolu-form-msg.is-error {
    color: var(--absolu-error);
}

.absolu-contact-info-side {
    background: var(--absolu-text);
    color: var(--absolu-white);
    padding: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.absolu-contact-info-side h2 {
    font-family: var(--absolu-font);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--absolu-white);
    margin: 0 0 32px;
    letter-spacing: -0.01em;
}

.absolu-info-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 28px;
}

.absolu-info-item i {
    font-size: 20px;
    color: var(--absolu-secondary);
    flex-shrink: 0;
    margin-top: 2px;
}

.absolu-info-item div {
    display: flex;
    flex-direction: column;
}

.absolu-info-label {
    font-family: var(--absolu-font);
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--absolu-secondary);
    margin-bottom: 4px;
}

.absolu-info-value {
    font-size: 0.9375rem;
    color: #ccc;
    line-height: 1.6;
}

.absolu-info-value a {
    color: #ccc;
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-info-value a:hover {
    color: var(--absolu-white);
}

.absolu-contact-socials {
    margin-top: 40px;
    padding-top: 32px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.absolu-contact-socials p {
    font-family: var(--absolu-font);
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--absolu-secondary);
    margin: 0 0 16px;
}

.absolu-contact-socials-links {
    display: flex;
    gap: 20px;
}

.absolu-contact-socials-links a {
    color: #999;
    font-size: 22px;
    transition: color 0.2s ease;
    text-decoration: none;
}

.absolu-contact-socials-links a:hover {
    color: var(--absolu-white);
}

@media (max-width: 768px) {
    .absolu-contact-intro {
        margin-bottom: 40px;
    }

    .absolu-contact-channels {
        grid-template-columns: 1fr;
    }

    .absolu-contact-card {
        padding: 28px 20px;
        flex-direction: row;
        text-align: left;
        gap: 20px;
    }

    .absolu-contact-card i {
        margin-bottom: 0;
        font-size: 28px;
    }

    .absolu-contact-split {
        grid-template-columns: 1fr;
        min-height: auto;
        margin-bottom: 48px;
    }

    .absolu-contact-form-side {
        padding: 36px 24px;
    }

    .absolu-contact-info-side {
        padding: 36px 24px;
    }

    .absolu-contact-form-side h2,
    .absolu-contact-info-side h2 {
        font-size: 1.25rem;
    }

    .absolu-contact-row {
        grid-template-columns: 1fr;
    }

    .absolu-contact-form button {
        width: 100%;
    }

    .absolu-contact-socials-links {
        gap: 16px;
    }
}

/* FAQ Accordion */
.absolu-faq-list {
    max-width: 800px;
}

.absolu-faq-item {
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-faq-item summary {
    font-family: var(--absolu-font);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--absolu-text);
    padding: 20px 40px 20px 0;
    cursor: pointer;
    list-style: none;
    position: relative;
    transition: color 0.2s ease;
}

.absolu-faq-item summary::-webkit-details-marker {
    display: none;
}

.absolu-faq-item summary::after {
    content: '+';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--absolu-font);
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--absolu-text-light);
    transition: transform 0.2s ease;
}

.absolu-faq-item[open] summary::after {
    content: '\2212';
}

.absolu-faq-item summary:hover {
    color: var(--absolu-primary);
}

.absolu-faq-item p {
    font-size: 0.9375rem;
    color: var(--absolu-text-light);
    line-height: 1.8;
    padding: 0 40px 24px 0;
    margin: 0;
}

.absolu-faq-item a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.absolu-faq-item a:hover {
    color: inherit;
}

/* Empty state */
.absolu-empty-state {
    text-align: center;
    padding: 80px 20px;
}

.absolu-empty-state i {
    font-size: 48px;
    color: var(--absolu-border);
    margin-bottom: 24px;
    display: block;
}

.absolu-empty-state h2 {
    font-size: 1.5rem;
    margin: 0 0 12px;
}

.absolu-empty-state p {
    color: var(--absolu-text-light);
    margin: 0 0 32px;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

/* 404 */
.absolu-404__code {
    font-family: var(--absolu-font);
    font-size: clamp(5rem, 12vw, 10rem);
    font-weight: 600;
    letter-spacing: -0.04em;
    color: var(--absolu-bg-light);
    display: block;
    line-height: 1;
    margin-bottom: 16px;
}

.absolu-404__actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

/* --------------------------------------------------------------------------
   14. Shop / Archive
   -------------------------------------------------------------------------- */

.absolu-archive-header {
    text-align: center;
    padding: 8px 0 48px;
    max-width: 800px;
    margin: 0 auto;
}

.absolu-archive-header__title {
    font-family: "OmegaCT", var(--absolu-font);
    font-size: 38px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--absolu-primary);
    margin: 0;
    line-height: 1.1;
}

.absolu-archive-header__desc {
    font-family: var(--absolu-font-body);
    font-size: 0.9rem;
    line-height: 1.8;
    color: var(--absolu-text-light);
    margin: 24px auto 0;
    max-width: 720px;
}

.absolu-product-grid--shop {
    grid-template-columns: repeat(5, 1fr);
}

.absolu-product-grid--related {
    grid-template-columns: repeat(4, 1fr);
}

.absolu-shop-filters {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0;
    margin-bottom: 28px;
    position: relative;
    z-index: 10;
}

.absolu-shop-count {
    margin-bottom: 32px;
}

.absolu-result-count {
    font-family: "OmegaCT", var(--absolu-font);
    font-size: 14px;
    font-weight: 700;
    color: var(--absolu-text);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    line-height: 16px;
}

.absolu-result-count strong {
    color: var(--absolu-primary);
    font-weight: 700;
}

.absolu-filters {
    display: flex;
    align-items: center;
    gap: 10px;
}

.absolu-filters__reset {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--absolu-text);
    text-decoration: none;
    border-bottom: 1px solid rgba(85, 85, 85, 0.5);
    padding-bottom: 5px;
    margin-left: 13px;
    white-space: nowrap;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.absolu-filters__reset:hover {
    color: var(--absolu-primary);
    border-bottom-color: var(--absolu-primary);
}

.absolu-filter {
    position: relative;
}

.absolu-filter__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--absolu-font);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 16px;
    text-transform: uppercase;
    text-align: left;
    color: var(--absolu-text);
    background: var(--absolu-bg-light);
    border: 1px solid transparent;
    border-radius: 100px;
    padding: 10px 24px;
    min-width: 120px;
    justify-content: center;
    cursor: pointer;
    white-space: nowrap;
    transition: border-color 0.2s ease;
}

.absolu-filter__btn:hover {
    border-color: transparent;
    background: #f2f2f2;
}

.absolu-filter__num {
    opacity: 0.5;
    margin-left: 2px;
    transition: opacity 0.15s ease;
}

.absolu-filter__btn:hover .absolu-filter__num {
    opacity: 1;
}

.absolu-filter__btn.is-active {
    padding-right: 0;
    gap: 6px;
    border-color: #cacaca;
}

.absolu-filter__clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    margin: -10px 0 -10px 8px;
    padding: 0 14px;
    border-left: 1px solid #d4d4d4;
    border-radius: 0 100px 100px 0;
    color: var(--absolu-text);
    font-size: 14px;
    line-height: 1;
    opacity: 0.45;
    transition: opacity 0.15s ease, background 0.15s ease;
    cursor: pointer;
}

.absolu-filter__clear:hover {
    opacity: 1;
    background: rgba(0, 0, 0, 0.04);
}

.absolu-filter__btn i {
    font-size: 12px;
    color: var(--absolu-text);
    transition: transform 0.2s ease;
}

.absolu-filter__btn.is-active i {
    display: none;
}

.absolu-filter.is-open .absolu-filter__btn {
    border-color: #cacaca;
}

.absolu-filter.is-open .absolu-filter__btn i {
    transform: rotate(180deg);
}

.absolu-filter__dropdown {
    display: none;
    flex-direction: column;
    align-items: stretch;
    position: absolute;
    top: 56px;
    left: 0;
    width: max-content;
    max-width: 300px;
    padding: 20px;
    border: 1px solid #e2e2e2;
    background: #fff;
    border-radius: 10px;
    text-align: left;
    max-height: min(500px, 50vh);
    z-index: 101;
}

.absolu-filter.is-open .absolu-filter__dropdown {
    display: flex;
}

.absolu-filter__dropdown--right {
    left: auto;
    right: 0;
}

.absolu-filter__dropdown--scrollable .absolu-filter__options {
    max-height: 280px;
    overflow-y: auto;
}

.absolu-filter__options {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin: 0 -20px;
}

.absolu-filter__check {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 20px;
    cursor: pointer;
}

.absolu-filter__check:hover .absolu-filter__label {
    color: var(--absolu-primary);
}

.absolu-filter__check input {
    display: none;
}

.absolu-filter__checkbox {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 24px;
    width: 24px;
    height: 24px;
    border: 1px solid var(--absolu-input-active);
    position: relative;
    transition: border 0.15s;
}

.absolu-filter__checkbox::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    right: 3px;
    bottom: 3px;
    background: var(--absolu-primary);
    transform: scale(0);
    transition: transform 0.2s ease;
}

.absolu-filter__check input:checked+.absolu-filter__checkbox {
    border-color: #999;
}

.absolu-filter__check input:checked+.absolu-filter__checkbox::after {
    transform: scale(1);
}

.absolu-filter__check--radio .absolu-filter__checkbox {
    border-radius: 50%;
}

.absolu-filter__check--radio .absolu-filter__checkbox::after {
    border-radius: 50%;
}

.absolu-filter__label {
    font-family: var(--absolu-font);
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 0.1em;
    text-align: left;
    color: var(--absolu-text);
    flex: 1;
}

.absolu-filter__count {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    color: var(--absolu-text-light);
    margin-left: auto;
}

.absolu-filter__search {
    padding: 0 0 12px;
    margin: 0 0 8px;
    border-bottom: 1px solid #e2e2e2;
}

.absolu-filter__search-input {
    width: 100%;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    padding: 8px 10px;
    border: 1px solid var(--absolu-border);
    outline: none;
    color: var(--absolu-text);
}

.absolu-filter__search-input:focus {
    border-color: #999;
}

.absolu-filter__search-input::placeholder {
    color: #aaa;
}

.absolu-filter__price-inputs {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0;
}

.absolu-filter__price-field {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.absolu-filter__price-label {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--absolu-text-light);
}

.absolu-filter__price-input {
    width: 100%;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    padding: 8px 10px;
    border: 1px solid var(--absolu-border);
    outline: none;
    color: var(--absolu-text);
    -moz-appearance: textfield;
}

.absolu-filter__price-input::-webkit-inner-spin-button,
.absolu-filter__price-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.absolu-filter__price-input:focus {
    border-color: #999;
}

.absolu-filter__price-sep {
    font-size: 1rem;
    color: var(--absolu-text-light);
    padding-top: 18px;
}

.absolu-filter__close {
    display: block;
    width: calc(100% + 40px);
    margin: 20px -20px -20px;
    padding: 14px 20px;
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    background: none;
    border: none;
    border-top: 1px solid #e2e2e2;
    border-radius: 0 0 10px 10px;
    cursor: pointer;
    transition: background 0.15s ease;
}

.absolu-filter__close:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

/* Pagination */
.absolu-pagination {
    margin-top: 60px;
    text-align: center;
}

.absolu-pagination ul {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 0;
    margin: 0;
}

.absolu-pagination li {
    display: inline-flex;
}

.absolu-pagination a,
.absolu-pagination span {
    font-family: var(--absolu-font);
    font-size: 0.8125rem;
    font-weight: 500;
    padding: 10px 16px;
    color: var(--absolu-text-light);
    text-decoration: none;
    transition: color 0.2s ease, background 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.absolu-pagination a:hover {
    color: var(--absolu-text);
}

.absolu-pagination .current {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

/* Skeleton loading cards */
.absolu-skeleton {
    pointer-events: none;
}

.absolu-skeleton__image {
    width: 100%;
    aspect-ratio: 3 / 4;
    background: #f0f0f0;
    border-radius: 4px;
    animation: absolu-pulse 1.4s ease-in-out infinite;
}

.absolu-skeleton__info {
    padding: 20px 8px 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.absolu-skeleton__line {
    height: 10px;
    background: #f0f0f0;
    border-radius: 4px;
    width: 100%;
    animation: absolu-pulse 1.4s ease-in-out infinite;
}

.absolu-skeleton__line--short {
    width: 40%;
}

.absolu-skeleton__line--medium {
    width: 30%;
}

@keyframes absolu-pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.4;
    }
}

/* Load More (legacy) */
.absolu-load-more-wrap {
    text-align: center;
    margin-top: 48px;
}

.absolu-load-more {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--absolu-text);
    background: none;
    border: 1px solid var(--absolu-text);
    padding: 14px 48px;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.absolu-load-more:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

.absolu-load-more.is-loading {
    opacity: 0.6;
    pointer-events: none;
}

/* Search results (non-product) */
.absolu-search-result {
    padding: 24px 0;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-search-result h3 {
    font-size: 1rem;
    margin: 0 0 8px;
}

.absolu-search-result h3 a {
    color: var(--absolu-text);
    text-decoration: none;
}

.absolu-search-result h3 a:hover {
    color: var(--absolu-primary);
}

.absolu-search-result p {
    font-size: 0.875rem;
    color: var(--absolu-text-light);
    margin: 0;
}

/* --------------------------------------------------------------------------
   15. Single Product
   -------------------------------------------------------------------------- */

.absolu-sp-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(32px, 5vw, 80px);
    align-items: start;
    margin-bottom: clamp(48px, 7vw, 100px);
}

/* -- Gallery -- */

.absolu-sp-gallery {
    position: sticky;
    top: 100px;
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 12px;
}

.absolu-sp-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
    background: var(--absolu-primary);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    padding: 6px 12px;
}

.absolu-sp-gallery__main {
    background: none;
    overflow: hidden;
    position: relative;
    order: 2;
}

.absolu-sp-gallery__img {
    width: 100%;
    display: block;
    object-fit: contain;
    aspect-ratio: 4 / 5;
    transition: opacity 0.15s ease;
}

.absolu-sp-gallery__thumbs {
    display: flex;
    flex-direction: column;
    gap: 8px;
    order: 1;
    overflow-y: auto;
    max-height: 520px;
    scrollbar-width: none;
}

.absolu-sp-gallery__thumbs::-webkit-scrollbar {
    display: none;
}

.absolu-sp-gallery__thumb {
    width: 72px;
    height: 72px;
    flex-shrink: 0;
    border: 1px solid var(--absolu-border);
    background: var(--absolu-bg-light);
    cursor: pointer;
    padding: 4px;
    transition: border-color 0.2s ease;
    overflow: hidden;
}

.absolu-sp-gallery__thumb.is-active {
    border-color: var(--absolu-text);
}

.absolu-sp-gallery__thumb:hover {
    border-color: var(--absolu-text-light);
}

.absolu-sp-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* -- Details -- */

.absolu-sp-details {
    padding-top: 8px;
}

.absolu-sp-details__inner {
    max-width: 520px;
}

.absolu-sp-brand {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--absolu-secondary);
    text-decoration: none;
    display: inline-block;
    margin-bottom: 16px;
    transition: color 0.2s ease;
}

.absolu-sp-brand:hover {
    color: var(--absolu-primary);
}

.absolu-sp-title {
    font-family: var(--absolu-font);
    font-size: clamp(1.625rem, 2.8vw, 2.25rem);
    font-weight: 400;
    letter-spacing: -0.02em;
    margin: 0 0 24px;
    line-height: 1.15;
    color: var(--absolu-text);
}

.absolu-sp-price {
    font-family: var(--absolu-font);
    font-size: 1.375rem;
    font-weight: 500;
    color: var(--absolu-text);
    margin-bottom: 28px;
    display: flex;
    align-items: baseline;
    gap: 12px;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-sp-price del {
    color: var(--absolu-strike);
    font-weight: 400;
    font-size: 1rem;
}

.absolu-sp-price ins {
    color: var(--absolu-primary);
    font-weight: 600;
    text-decoration: none;
}

.absolu-sp-excerpt {
    font-family: var(--absolu-font-body);
    font-size: 0.9375rem;
    color: var(--absolu-text-light);
    line-height: 1.8;
    margin-bottom: 32px;
}

.absolu-sp-excerpt p:last-child {
    margin-bottom: 0;
}

/* -- Actions (ATC + Wishlist) -- */

.absolu-sp-actions {
    display: flex;
    gap: 12px;
    align-items: stretch;
    margin-bottom: 36px;
}

.absolu-sp-form {
    display: flex;
    gap: 0;
    flex: 1;
}

.absolu-sp-qty {
    display: flex;
    align-items: center;
    border: 1px solid var(--absolu-border);
    flex-shrink: 0;
}

.absolu-qty-btn {
    width: 44px;
    height: 52px;
    border: none;
    background: none;
    font-size: 0.875rem;
    cursor: pointer;
    color: var(--absolu-text);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease, color 0.2s ease;
}

.absolu-qty-btn:hover {
    background: var(--absolu-bg-light);
    color: var(--absolu-primary);
}

.absolu-qty-input {
    width: 44px;
    height: 52px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--absolu-border);
    border-right: 1px solid var(--absolu-border);
    font-family: var(--absolu-font);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--absolu-text);
    appearance: textfield;
    -moz-appearance: textfield;
    padding: 0;
}

.absolu-qty-input::-webkit-outer-spin-button,
.absolu-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.absolu-sp-atc {
    flex: 1;
    background: var(--absolu-text);
    color: var(--absolu-white);
    border: none;
    font-family: var(--absolu-font);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
    padding: 0 28px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background 0.25s ease;
}

.absolu-sp-atc i {
    font-size: 1rem;
}

.absolu-sp-atc:hover {
    background: var(--absolu-primary);
}

.absolu-sp-atc.is-loading {
    opacity: 0.7;
    pointer-events: none;
}

.absolu-sp-atc.is-added {
    background: #2e7d32;
    pointer-events: none;
}

.absolu-sp-atc__text {
    display: inline-block;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.absolu-sp-atc.is-loading .absolu-sp-atc__text {
    opacity: 0.6;
}

.absolu-sp-atc.is-added .absolu-sp-atc__text {
    animation: atcAdded 0.35s ease;
}

@keyframes atcAdded {
    0% { opacity: 0; transform: translateY(6px); }
    100% { opacity: 1; transform: translateY(0); }
}

.absolu-sp-wishlist {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: 1px solid var(--absolu-border);
    cursor: pointer;
    color: var(--absolu-text-light);
    transition: color 0.2s ease, border-color 0.2s ease;
}

.absolu-sp-wishlist i {
    font-size: 1.25rem;
    line-height: 1;
}

.absolu-sp-wishlist:hover {
    color: var(--absolu-text);
    border-color: var(--absolu-text);
}

.absolu-sp-wishlist.is-active {
    color: var(--absolu-primary);
    border-color: var(--absolu-primary);
    animation: absoluHeartPop 0.35s ease;
}

.absolu-sp-wishlist.is-active i {
    font-family: "Phosphor-Fill" !important;
}

.absolu-sp-outofstock {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text-light);
    padding: 16px 20px;
    background: var(--absolu-bg-light);
    flex: 1;
}

.absolu-sp-outofstock i {
    font-size: 1.125rem;
}

/* -- Trust -- */

.absolu-sp-trust {
    display: flex;
    gap: 24px;
    padding: 20px 0;
    border-top: 1px solid var(--absolu-border);
    border-bottom: 1px solid var(--absolu-border);
    margin-bottom: 28px;
}

.absolu-sp-trust__item {
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    color: var(--absolu-text-light);
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.absolu-sp-trust__item i {
    font-size: 16px;
    color: var(--absolu-text);
}

/* -- Meta -- */

.absolu-sp-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 24px;
}

.absolu-sp-meta__item {
    font-size: 0.8125rem;
    color: var(--absolu-text-light);
    display: flex;
    gap: 8px;
    padding: 4px 0;
}

.absolu-sp-meta__label {
    font-family: var(--absolu-font);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.6875rem;
    color: var(--absolu-text);
}

.absolu-sp-meta__value {
    font-family: var(--absolu-font-body);
}

/* -- Description -- */

.absolu-sp-description {
    padding: clamp(40px, 6vw, 72px) 0;
    border-top: 1px solid var(--absolu-border);
}

.absolu-sp-description h2 {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 24px;
    color: var(--absolu-text);
}

.absolu-sp-description__content {
    font-family: var(--absolu-font-body);
    font-size: 0.9375rem;
    color: var(--absolu-text-light);
    line-height: 1.9;
    max-width: 720px;
}

.absolu-sp-description__content p {
    margin: 0 0 16px;
}

.absolu-sp-description__content.is-clamped {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.absolu-sp-description__toggle {
    display: none;
    background: none;
    border: none;
    padding: 0;
    margin-top: 8px;
    font-family: var(--absolu-font);
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--absolu-text);
    text-decoration: underline;
    text-underline-offset: 3px;
    cursor: pointer;
}

@media (max-width: 768px) {
    .absolu-sp-description__content {
        font-size: 0.84rem;
    }

    .absolu-sp-description__toggle {
        display: inline-block;
    }
}

/* -- Related -- */

.absolu-sp-related {
    padding: clamp(40px, 6vw, 72px) 0 0;
    border-top: 1px solid var(--absolu-border);
}

/* --------------------------------------------------------------------------
   16. Cart
   -------------------------------------------------------------------------- */

.absolu-btn--sm {
    padding: 10px 24px;
    font-size: 0.6875rem;
}

.absolu-btn--primary {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-white);
    background: var(--absolu-text);
    border: none;
    padding: 14px 36px;
    text-decoration: none;
    transition: background 0.2s ease;
    cursor: pointer;
}

.absolu-btn--primary:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

/* Cart two-column layout */
.absolu-page--cart .woocommerce {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 48px;
    align-items: start;
}

/* Cart table */
.absolu-cart-table {
    width: 100%;
    border-collapse: collapse;
    border: none;
}

.absolu-cart-table thead th {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    text-align: left;
    padding: 0 0 16px;
    border-bottom: 1px solid var(--absolu-border);
    background: none;
}

.absolu-cart-table thead .absolu-cart-table__col--qty,
.absolu-cart-table thead .absolu-cart-table__col--total {
    text-align: center;
}

.absolu-cart-table thead .absolu-cart-table__col--remove {
    width: 40px;
}

/* Cart item rows */
.absolu-cart-item td {
    padding: 24px 0;
    border-bottom: 1px solid var(--absolu-border);
    vertical-align: middle;
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
}

.absolu-cart-item__img {
    width: 80px;
    padding-right: 20px;
}

.absolu-cart-item__img img {
    width: 80px;
    height: 80px;
    object-fit: contain;
    background: var(--absolu-bg-light);
    display: block;
}

.absolu-cart-item__img a {
    display: block;
    line-height: 0;
}

.absolu-cart-item__name a {
    font-family: var(--absolu-font);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--absolu-text);
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-cart-item__name a:hover {
    color: var(--absolu-primary);
}

.absolu-cart-item__name dl.variation {
    margin: 8px 0 0;
}

.absolu-cart-item__name dl.variation dt,
.absolu-cart-item__name dl.variation dd {
    display: inline;
    font-size: 0.8125rem;
    color: var(--absolu-text-light);
    margin: 0;
}

.absolu-cart-item__name dl.variation dd p {
    display: inline;
    margin: 0;
}

.absolu-cart-item__price,
.absolu-cart-item__total {
    font-family: var(--absolu-font);
    font-weight: 500;
    white-space: nowrap;
}

.absolu-cart-item__total {
    text-align: center;
}

.absolu-cart-item__qty {
    text-align: center;
}

.absolu-cart-item__qty .quantity input[type="number"] {
    width: 56px;
    height: 40px;
    text-align: center;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font);
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0;
    appearance: textfield;
    -moz-appearance: textfield;
    background: var(--absolu-white);
    transition: border-color 0.2s ease;
}

.absolu-cart-item__qty .quantity input[type="number"]:focus {
    border-color: var(--absolu-text);
    outline: none;
}

.absolu-cart-item__qty .quantity input::-webkit-inner-spin-button,
.absolu-cart-item__qty .quantity input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.absolu-cart-item__remove {
    text-align: center;
    width: 40px;
}

.absolu-cart-remove {
    color: var(--absolu-text-light);
    font-size: 1.125rem;
    opacity: 0.4;
    transition: opacity 0.2s ease, color 0.2s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.absolu-cart-remove:hover {
    opacity: 1;
    color: var(--absolu-primary);
}

/* Cart actions */
.absolu-cart-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 24px;
}

.absolu-cart-actions .absolu-btn--outline.absolu-btn--sm {
    padding: 10px 20px;
}

/* Cart totals sidebar */
.absolu-cart-totals-wrap {
    width: 100%;
}

.absolu-cart-totals {
    background: var(--absolu-bg-light);
    padding: 40px;
    position: sticky;
    top: 120px;
}

.absolu-cart-totals h2 {
    font-family: var(--absolu-font);
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0 0 28px;
}

.absolu-totals-table {
    width: 100%;
    border-collapse: collapse;
    border: none;
}

.absolu-totals-table th,
.absolu-totals-table td {
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    padding: 14px 0;
    border-top: none;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-totals-table th {
    font-weight: 400;
    color: var(--absolu-text-light);
    text-align: left;
    width: 40%;
}

.absolu-totals-table td {
    text-align: right;
    font-weight: 500;
    color: var(--absolu-text);
}

.absolu-totals-total th,
.absolu-totals-total td {
    font-family: var(--absolu-font);
    font-weight: 600;
    font-size: 1.125rem;
    color: var(--absolu-text);
    border-bottom: none;
    padding-top: 20px;
}

/* Shipping row in cart totals */
.absolu-totals-table .woocommerce-shipping-totals td {
    text-align: right;
}

.absolu-totals-table .woocommerce-shipping-totals ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-totals-table .woocommerce-shipping-totals li {
    font-size: 0.8125rem;
    padding: 4px 0;
}

.absolu-totals-table .woocommerce-shipping-totals label {
    font-weight: 400;
    font-size: 0.8125rem;
}

/* Proceed to checkout */
.absolu-cart-checkout .wc-proceed-to-checkout a,
.absolu-cart-checkout .checkout-button {
    display: block;
    width: 100%;
    text-align: center;
    background: var(--absolu-text);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 16px;
    text-decoration: none;
    transition: background 0.2s ease;
    margin-top: 24px;
    border-radius: 0;
    border: none;
    cursor: pointer;
}

.absolu-cart-checkout .wc-proceed-to-checkout a:hover,
.absolu-cart-checkout .checkout-button:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

/* Return to shop (empty cart) */
.woocommerce .return-to-shop a,
.woocommerce .wc-backward {
    background: var(--absolu-text);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 14px 32px;
    text-decoration: none;
    transition: background 0.2s ease;
    border-radius: 0;
}

.woocommerce .return-to-shop a:hover,
.woocommerce .wc-backward:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

/* WC notices on cart page */
.absolu-page--cart .woocommerce-notices-wrapper {
    grid-column: 1 / -1;
}

.absolu-page--cart .woocommerce-notices-wrapper:empty {
    display: none;
}

/* Empty cart: single column, no grid */
.absolu-page--cart .wc-empty-cart-message {
    grid-column: 1 / -1;
}

.absolu-page--cart .wc-empty-cart-message+.absolu-empty-state {
    grid-column: 1 / -1;
}

.absolu-page--cart .absolu-empty-state {
    grid-column: 1 / -1;
}

/* Hide WC default empty cart message (we have custom one) */
.absolu-page--cart .wc-empty-cart-message .cart-empty {
    display: none;
}

/* --------------------------------------------------------------------------
   17. Checkout
   -------------------------------------------------------------------------- */

/* Page-level: kill all padding on checkout */
.absolu-page--checkout,
.absolu-page--checkout.absolu-page {
    padding: 0;
}

.absolu-page--checkout .absolu-breadcrumbs,
.absolu-page--checkout .absolu-page-header {
    display: none;
}

/* Checkout container */
.absolu-checkout-container {
    max-width: 1320px;
    margin: 0 auto;
    padding: 50px var(--absolu-gap);
}

/* Wrapper */
.absolu-checkout-wrap {
    width: 100%;
}

/* Hide coupon & login toggles */
.absolu-checkout-wrap .woocommerce-form-coupon-toggle,
.absolu-checkout-wrap .woocommerce-form-login-toggle {
    display: none;
}

/* WC notices */
.absolu-checkout-wrap .woocommerce-NoticeGroup {
    margin-bottom: 24px;
}

.absolu-checkout-wrap .woocommerce-error,
.absolu-checkout-wrap .woocommerce-message {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    padding: 14px 20px;
    border: none;
    background: var(--absolu-bg-light);
    color: var(--absolu-text);
    list-style: none;
}

.absolu-checkout-wrap .woocommerce-error::before,
.absolu-checkout-wrap .woocommerce-message::before {
    display: none;
}

/* -- Secure checkout badge -- */
.absolu-checkout-secure svg {
    color: #2e7d32;
}

/* =======  Two-column grid  ======= */
.absolu-checkout-grid {
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: 80px;
    align-items: start;
}

/* -- Left column: form -- */
.absolu-checkout-fields {
    min-width: 0;
    padding-top: 8px;
}

/* Section heading */
.absolu-checkout-section h3 {
    font-family: var(--absolu-font);
    font-size: 0.8125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0 0 32px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--absolu-border);
    color: var(--absolu-text);
}

/* Field grid */
.absolu-checkout .woocommerce-billing-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px 24px;
}

.absolu-checkout p:not(.absolu-checkout-legal),
.absolu-checkout .form-row {
    margin: 0;
    padding: 0;
}

/* Inline field validation error text */
.absolu-checkout .checkout-inline-error-message {
    font-size: 0.625rem;
    color: var(--absolu-primary);
    margin-top: 4px;
    font-weight: 400;
}

.absolu-checkout .form-row-wide {
    grid-column: 1 / -1;
}

.absolu-checkout .form-row-first {
    grid-column: 1;
}

.absolu-checkout .form-row-last {
    grid-column: 2;
}

/* Labels */
.absolu-checkout .woocommerce-billing-fields label,
.absolu-checkout .woocommerce-additional-fields label {
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 8px;
}

.absolu-checkout label .required {
    color: var(--absolu-primary);
}

/* Inputs */
.absolu-checkout .input-text,
.absolu-checkout select {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    background: var(--absolu-white);
    border-radius: 0;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
    -webkit-appearance: none;
}

.absolu-checkout .input-text:focus,
.absolu-checkout select:focus {
    border-color: var(--absolu-text);
    box-shadow: none;
    outline: none;
}

.absolu-checkout .input-text::placeholder {
    color: var(--absolu-strike);
    font-weight: 300;
}

/* Select2 -- full reset & rebuild */

/* Reset all Select2 defaults */
.absolu-checkout .select2-container,
.absolu-checkout .select2-container *,
.absolu-account-content .select2-container,
.absolu-account-content .select2-container * {
    box-sizing: border-box;
}

/* -- Trigger (closed state) -- */
.absolu-checkout .select2-container--default .select2-selection--single,
.absolu-account-content .select2-container--default .select2-selection--single {
    height: 50px;
    border: 1px solid var(--absolu-border);
    border-radius: 0;
    background: var(--absolu-white);
    outline: none;
    transition: border-color 0.2s ease;
}

.absolu-checkout .select2-container--default.select2-container--open .select2-selection--single,
.absolu-checkout .select2-container--default.select2-container--focus .select2-selection--single,
.absolu-account-content .select2-container--default.select2-container--open .select2-selection--single,
.absolu-account-content .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--absolu-text);
    box-shadow: none;
}

/* -- Selected text -- */
.absolu-checkout .select2-container--default .select2-selection--single .select2-selection__rendered,
.absolu-account-content .select2-container--default .select2-selection--single .select2-selection__rendered {
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    line-height: 50px;
    padding: 0 36px 0 16px;
}

/* -- Arrow -- */
.absolu-checkout .select2-container--default .select2-selection--single .select2-selection__arrow,
.absolu-account-content .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 50px;
    width: 36px;
    right: 0;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.absolu-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b,
.absolu-account-content .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border: none;
    width: 8px;
    height: 8px;
    border-right: 1.5px solid var(--absolu-text-light);
    border-bottom: 1.5px solid var(--absolu-text-light);
    transform: rotate(45deg);
    margin-top: -4px;
    position: static;
    left: auto;
    top: auto;
}

.absolu-checkout .select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b,
.absolu-account-content .select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
    transform: rotate(-135deg);
    margin-top: 2px;
}

/* -- Dropdown panel -- */
.select2-container--default .select2-dropdown {
    border: 1px solid var(--absolu-border);
    border-top: none;
    border-radius: 0;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
    background: var(--absolu-white);
    z-index: 999999;
}

/* -- Search input -- */
.select2-container--default .select2-search--dropdown {
    padding: 10px 12px;
    border-bottom: 1px solid var(--absolu-border);
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    width: 100%;
    border: none;
    border-bottom: 1px solid var(--absolu-border);
    border-radius: 0;
    padding: 6px 0;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    color: var(--absolu-text);
    outline: none;
    background: transparent;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    border-bottom-color: var(--absolu-text);
    outline: none;
    box-shadow: none;
}

/* -- Options list -- */
.select2-container--default .select2-results>.select2-results__options {
    max-height: 200px;
    padding: 4px 0;
    overflow-y: auto;
}

/* Thin scrollbar */
.select2-container--default .select2-results>.select2-results__options::-webkit-scrollbar {
    width: 3px;
}

.select2-container--default .select2-results>.select2-results__options::-webkit-scrollbar-track {
    background: transparent;
}

.select2-container--default .select2-results>.select2-results__options::-webkit-scrollbar-thumb {
    background: var(--absolu-border);
}

/* -- Each option -- */
.select2-container--default .select2-results__option {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    font-weight: 400;
    color: var(--absolu-text);
    padding: 7px 12px;
    background: transparent;
    transition: color 0.15s ease;
    cursor: pointer;
    outline: none;
}

/* Hover */
.select2-container--default .select2-results__option--highlighted,
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected] {
    background: transparent;
    color: var(--absolu-primary);
}

/* Selected */
.select2-container--default .select2-results__option[aria-selected="true"],
.select2-container--default .select2-results__option[data-selected="true"] {
    background: transparent;
    background-color: transparent;
    color: var(--absolu-primary);
}

/* No results */
.select2-container--default .select2-results__message {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    color: var(--absolu-text-light);
    padding: 10px 12px;
}

/* Hide Stripe dev assistant */
#stripe-developer-tools-assistant,
.stripe-developer-tools-assistant {
    display: none;
}

/* Address line 2: subtle separator */
.absolu-checkout #billing_address_2_field {
    margin-top: -8px;
}

/* =======  Right column: order sidebar  ======= */
.absolu-checkout-sidebar {
    position: sticky;
    top: 100px;
}

.absolu-checkout-order {
    background: var(--absolu-bg-light);
    padding: 36px;
}

.absolu-checkout-order>h3 {
    font-family: var(--absolu-font);
    font-size: 0.8125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0 0 24px;
    padding: 0;
    border: none;
    color: var(--absolu-text);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.absolu-checkout-count {
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--absolu-text-light);
}

/* =======  Order Review Table  ======= */

.absolu-checkout-order .woocommerce-checkout-review-order-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0;
}

/* Hide table header */
.absolu-checkout-order .woocommerce-checkout-review-order-table thead {
    display: none;
}

/* All cells base */
.absolu-checkout-order .woocommerce-checkout-review-order-table th,
.absolu-checkout-order .woocommerce-checkout-review-order-table td {
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    padding: 14px 0;
    border-bottom: 1px solid var(--absolu-border);
    border-top: none;
    vertical-align: top;
}

/* -- Product rows -- */
.absolu-checkout-order .cart_item .product-name {
    text-align: left;
    color: var(--absolu-text);
    font-weight: 400;
    line-height: 1.5;
    padding-right: 32px;
}

.absolu-checkout-order .cart_item .product-name .product-quantity {
    font-weight: 400;
    color: var(--absolu-text);
    font-size: 0.6875rem;
    margin-left: 2px;
}

.absolu-checkout-order .cart_item .product-total {
    text-align: right;
    white-space: nowrap;
    font-weight: 500;
    color: var(--absolu-text);
    padding-left: 8px;
}

/* -- Subtotal -- */
.absolu-checkout-order .cart-subtotal th,
.absolu-checkout-order .cart-subtotal td {
    border: none;
    padding: 20px 0 6px;
}

.absolu-checkout-order .cart-subtotal th {
    text-align: left;
    font-weight: 400;
    color: var(--absolu-text-light);
    font-size: 0.8125rem;
}

.absolu-checkout-order .cart-subtotal td {
    text-align: right;
    font-weight: 500;
    color: var(--absolu-text);
}

/* Hide shipping row in table (rendered as standalone div instead) */
.absolu-checkout-order .woocommerce-shipping-totals {
    display: none;
}

/* -- Shipping standalone row (inside table, colspan=2) -- */
.absolu-shipping-standalone td {
    border: none;
    padding: 6px 0;
}

.absolu-shipping-flex {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
}

.absolu-shipping-flex__label {
    color: var(--absolu-text-light);
    flex-shrink: 0;
}

.absolu-shipping-flex__value {
    text-align: right;
    color: var(--absolu-text);
}

.absolu-shipping-flex__value ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-shipping-flex__value li {
    display: inline;
}

.absolu-shipping-flex__value label {
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    font-weight: 400;
    color: var(--absolu-text-light);
    text-transform: none;
    letter-spacing: 0;
}

.absolu-shipping-flex__value li:only-child input[type="radio"] {
    display: none;
}

.absolu-shipping-flex__value .woocommerce-Price-amount {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--absolu-text);
}

.absolu-shipping-flex__value p {
    font-size: 0.75rem;
    color: #999;
    margin: 0;
}

/* -- Total -- strongest visual weight */
.absolu-checkout-order .order-total th,
.absolu-checkout-order .order-total td {
    font-family: var(--absolu-font);
    font-weight: 700;
    font-size: 1.125rem;
    letter-spacing: 0.04em;
    color: var(--absolu-text);
    border-top: 2px solid var(--absolu-text);
    border-bottom: none;
    padding: 20px 0 4px;
}

.absolu-checkout-order .order-total th {
    text-align: left;
    text-transform: uppercase;
}

.absolu-checkout-order .order-total td {
    text-align: right;
}

/* -- Payment section -- */
.absolu-checkout p.absolu-checkout-secure {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--absolu-font);
    font-size: 0.9rem;
    text-transform: none;
    letter-spacing: normal;
    font-weight: 400;
    color: var(--absolu-text-light);
    margin: 20px 0 0;
    padding: 0;
}

.absolu-checkout-secure svg {
    flex-shrink: 0;
}

.absolu-checkout-order .wc_payment_methods {
    list-style: none;
    padding: 20px 0 0;
    margin: 20px 0 0;
    border-top: 1px solid var(--absolu-border);
}

.absolu-checkout-order .wc_payment_method {
    padding: 0;
    border: none;
}

.absolu-checkout-order .wc_payment_method label {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--absolu-text);
    display: flex;
    align-items: center;
    gap: 6px;
}

.absolu-checkout-order .wc_payment_method label img {
    vertical-align: middle;
    margin-left: 4px;
}

.absolu-checkout-order .payment_box {
    background: none;
    padding: 12px 0 0;
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    color: var(--absolu-text-light);
    line-height: 1.5;
}

.absolu-checkout-order .payment_box::before {
    display: none;
}

/* Saved payment methods */
.absolu-checkout-order .woocommerce-SavedPaymentMethods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-checkout-order .woocommerce-SavedPaymentMethods li {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
}

.absolu-checkout-order .woocommerce-SavedPaymentMethods label {
    font-size: 0.75rem;
    font-weight: 400;
}

/* Custom radio for checkout (matches shop filter style) */
.absolu-checkout-order .wc_payment_method input[type="radio"],
.absolu-checkout-order .woocommerce-SavedPaymentMethods input[type="radio"] {
    -webkit-appearance: none;
    appearance: none;
    width: 22px;
    height: 22px;
    min-width: 22px;
    min-height: 22px;
    border: 1px solid var(--absolu-input-active);
    border-radius: 0;
    background: none;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    transition: border 0.15s;
    display: inline-block;
    box-sizing: border-box;
}

.absolu-checkout-order .wc_payment_method input[type="radio"]::after,
.absolu-checkout-order .woocommerce-SavedPaymentMethods input[type="radio"]::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    right: 3px;
    bottom: 3px;
    background: var(--absolu-primary);
    border-radius: 0;
    transform: scale(0);
    transition: transform 0.2s ease;
}

.absolu-checkout-order .wc_payment_method input[type="radio"]:checked,
.absolu-checkout-order .woocommerce-SavedPaymentMethods input[type="radio"]:checked {
    border-color: #999;
}

.absolu-checkout-order .wc_payment_method input[type="radio"]:checked::after,
.absolu-checkout-order .woocommerce-SavedPaymentMethods input[type="radio"]:checked::after {
    transform: scale(1);
}

/* Hide "save payment" fieldset */
.absolu-checkout-order .payment_box fieldset {
    display: none;
}

/* Hide test mode notice */
.absolu-checkout-order .payment_box .testmode-info,
.absolu-checkout-order .payment_box p[style*="color"] {
    display: none;
}

/* -- PLACE ORDER -- second highest visual priority */
.absolu-checkout-order #place_order {
    display: block;
    width: 100%;
    background: var(--absolu-primary);
    color: var(--absolu-white);
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 22px 20px;
    border: none;
    cursor: pointer;
    margin-top: 28px;
    border-radius: 0;
    text-align: center;
    position: relative;
    overflow: hidden;
    z-index: 1;
    transition: transform 0.15s ease;
}

.absolu-checkout-order #place_order::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 100%;
    background: var(--absolu-secondary);
    transform: translateY(100%);
    transition: transform 0.35s ease;
    z-index: -1;
}

.absolu-checkout-order #place_order:hover::before {
    transform: translateY(0);
}

.absolu-checkout-order #place_order:active {
    transform: scale(0.985);
}

/* Hide default WC terms/privacy (replaced by custom text) */
.absolu-checkout-order .woocommerce-terms-and-conditions-wrapper,
.absolu-checkout-order .woocommerce-privacy-policy-text {
    display: none;
}

/* Custom legal text below Place Order */
.absolu-checkout-legal {
    font-family: var(--absolu-font-body);
    font-size: 0.625rem;
    color: var(--absolu-text-light);
    text-align: center;
    margin-top: 30px;
    line-height: 1.6;
}

.absolu-checkout-legal a {
    color: #888;
    text-decoration: underline;
}

.absolu-checkout-legal a:hover {
    color: var(--absolu-text);
}

/* =======  Checkout page load animations  ======= */
@keyframes absolu-checkout-fade-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.absolu-checkout-secure {
    animation: none;
}

.absolu-checkout-section {
    animation: absolu-checkout-fade-up 0.5s ease both;
    animation-delay: 0.1s;
}

.absolu-checkout-order {
    animation: absolu-checkout-fade-up 0.5s ease both;
    animation-delay: 0.2s;
}

/* =======  Mobile: stack  ======= */
@media (max-width: 1024px) {
    .absolu-checkout-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .absolu-checkout-sidebar {
        position: static;
    }

    .absolu-checkout-container {
        padding: 24px var(--absolu-gap);
    }
}

@media (max-width: 600px) {
    .absolu-checkout .woocommerce-billing-fields__field-wrapper {
        grid-template-columns: 1fr;
    }

    .absolu-checkout .form-row-first,
    .absolu-checkout .form-row-last {
        grid-column: 1;
    }

    .absolu-checkout-order {
        padding: 24px;
    }
}

/* --------------------------------------------------------------------------
   18. My Account
   -------------------------------------------------------------------------- */

/* Account page header -- left when logged in, center when logged out */
/* Account page spacing -- single source */

.woocommerce-account.logged-in .absolu-archive-header {
    text-align: left;
    margin: 0;
}

.woocommerce-account:not(.logged-in) .absolu-archive-header {
    padding: 8px 0 24px;
}


/* -- Logged-in Layout -- */

.absolu-account-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 0;
    align-items: start;
}

/* -- Sidebar Nav -- */

.absolu-account-nav {
    padding-right: 32px;
}

.absolu-account-nav .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--downloads {
    display: none;
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--customer-logout {
    margin-top: 16px;
    padding-top: 22px;
    border-top: 1px solid var(--absolu-border);
}

.absolu-account-nav .woocommerce-MyAccount-navigation li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    text-decoration: none;
    background: none;
    border: 1px solid var(--absolu-border);
    transition: border-color 0.2s ease, color 0.2s ease;
}

.absolu-account-nav .woocommerce-MyAccount-navigation li a::before {
    font-family: 'Phosphor-Light';
    font-size: 18px;
    font-weight: normal;
    line-height: 1;
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--orders a::before {
    content: '\e390';
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--edit-address a::before {
    content: '\e316';
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--payment-methods a::before {
    content: '\e1d2';
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--edit-account a::before {
    content: '\e4c4';
}

.absolu-account-nav .woocommerce-MyAccount-navigation-link--customer-logout a::before {
    content: '\e42a';
}

.absolu-account-nav .woocommerce-MyAccount-navigation li a:hover {
    border-color: var(--absolu-primary);
    color: var(--absolu-primary);
}

.absolu-account-nav .woocommerce-MyAccount-navigation li.is-active a,
.absolu-account-nav .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
    border-color: var(--absolu-primary);
    color: var(--absolu-primary);
    font-weight: 600;
}

/* -- Account Content -- */

.absolu-account-content {
    min-height: 300px;
    padding-left: 48px;
}

.absolu-account-content mark {
    background: none;
    color: inherit;
}

/* Dashboard */
.absolu-dashboard__greeting {
    font-family: var(--absolu-font);
    font-size: 1rem;
    font-weight: 400;
    color: var(--absolu-text);
    margin: 0 0 28px;
}

.absolu-dashboard__greeting strong {
    font-weight: 600;
}

.absolu-dashboard__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 40px;
}

.absolu-dashboard__stat {
    border: 1px solid var(--absolu-border);
    padding: 20px;
    text-align: center;
}

.absolu-dashboard__stat-value {
    display: block;
    font-family: var(--absolu-font);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--absolu-text);
    margin-bottom: 4px;
}

.absolu-dashboard__stat-label {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
}

.absolu-dashboard__section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.absolu-dashboard__section-title {
    font-family: var(--absolu-font);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    margin: 0;
}

.absolu-dashboard__view-all {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    text-decoration: none;
    transition: color 0.2s ease;
}

.absolu-dashboard__view-all:hover {
    color: var(--absolu-primary);
}

/* View Order page */
.absolu-view-order__stats {
    margin-bottom: 32px;
}

.absolu-order-updates {
    margin-bottom: 32px;
}

.absolu-order-notes {
    list-style: none;
    padding: 0;
    margin: 16px 0 0;
}

.absolu-order-note {
    padding: 12px 0;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-order-note__date {
    font-size: 0.75rem;
    color: var(--absolu-text-light);
    margin: 0 0 4px;
}

.absolu-order-note__content {
    font-size: 0.85rem;
    color: var(--absolu-text);
}

.absolu-dashboard__orders {
    width: 100%;
    border-collapse: collapse;
}

.absolu-dashboard__orders th {
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    padding: 0 16px 12px;
    border-bottom: 1px solid var(--absolu-text);
    text-align: left;
}

.absolu-dashboard__orders td {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    padding: 14px 16px;
    border-bottom: 1px solid var(--absolu-border);
    color: var(--absolu-text-light);
}

.absolu-dashboard__orders td a {
    color: var(--absolu-text);
    text-decoration: none;
    font-weight: 500;
}

.absolu-dashboard__orders td a:hover {
    color: var(--absolu-primary);
}

.absolu-dashboard__status {
    font-weight: 500;
    text-transform: capitalize;
}

.absolu-dashboard__orders .absolu-dashboard__status {
    font-size: 0.7rem;
}


.absolu-dashboard__empty {
    text-align: center;
    padding: 60px 20px;
}

.absolu-dashboard__empty p {
    font-size: 0.88rem;
    color: var(--absolu-text-light);
    margin-bottom: 20px;
}

.absolu-dashboard__shop-link {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    text-decoration: none;
    border: 1px solid var(--absolu-text);
    padding: 10px 24px;
    transition: background 0.2s ease, color 0.2s ease;
}

.absolu-dashboard__shop-link:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

/* Empty orders welcome */
.absolu-empty-orders {
    text-align: center;
    padding: 60px 20px;
}

.absolu-empty-orders i {
    font-size: 48px;
    color: var(--absolu-border);
    display: block;
    margin-bottom: 20px;
}

.absolu-empty-orders h3 {
    font-family: var(--absolu-font);
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--absolu-text);
    margin: 0 0 12px;
}

.absolu-empty-orders p {
    font-family: var(--absolu-font-body);
    font-size: 0.85rem;
    color: var(--absolu-text-light);
    line-height: 1.7;
    max-width: 400px;
    margin: 0 auto 28px;
}

.absolu-empty-orders__btn {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    background: none;
    border: 1px solid var(--absolu-text);
    padding: 10px 24px;
    text-decoration: none;
    display: inline-block;
    transition: background 0.2s ease, color 0.2s ease;
}

a.absolu-empty-orders__btn {
    text-decoration: none;
}

.absolu-empty-orders__btn:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

.absolu-account-content .woocommerce-Address-title {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.absolu-account-content .woocommerce-Address-title h2 {
    margin: 0;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.absolu-account-content .woocommerce-Address-title .edit {
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    text-decoration: none;
    border: 1px solid var(--absolu-text);
    padding: 6px 14px;
    transition: background 0.2s ease, color 0.2s ease;
}

.absolu-account-content .woocommerce-Address-title .edit:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

.absolu-account-content address {
    font-style: normal;
    font-family: var(--absolu-font-body);
    font-size: 0.85rem;
    line-height: 1.8;
    color: var(--absolu-text-light);
}

.absolu-account-content p {
    font-size: 0.88rem;
    line-height: 1.8;
    color: var(--absolu-text-light);
}

.absolu-account-content p a {
    color: var(--absolu-text);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
}

.absolu-account-content p a:hover {
    color: var(--absolu-primary);
}

.absolu-account-content table {
    width: 100%;
    border-collapse: collapse;
}

.absolu-account-content table th,
.absolu-account-content table td {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    padding: 14px 16px;
    border-bottom: 1px solid var(--absolu-border);
    text-align: left;
    color: var(--absolu-text-light);
}

.absolu-account-content table th {
    font-family: var(--absolu-font);
    font-weight: 600;
    font-size: 0.65rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--absolu-text);
    padding-top: 0;
}

.absolu-account-content table td a {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text);
    text-decoration: none;
}

.absolu-account-content table td a:hover {
    color: var(--absolu-primary);
}

/* Account buttons */
.absolu-account-content .woocommerce-Button,
.absolu-account-content .button,
.absolu-account-content button[type="submit"],
.woocommerce .absolu-account-content a.button,
.woocommerce .absolu-account-content button.button,
.woocommerce .absolu-account-content input.button,
.woocommerce .absolu-account-content .button {
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: none;
    background-color: transparent;
    color: var(--absolu-text);
    border: 1px solid var(--absolu-text);
    padding: 10px 24px;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease;
    border-radius: 0;
}

.absolu-account-content .woocommerce-Button:hover,
.absolu-account-content .button:hover,
.absolu-account-content button[type="submit"]:hover,
.woocommerce .absolu-account-content a.button:hover,
.woocommerce .absolu-account-content button.button:hover,
.woocommerce .absolu-account-content input.button:hover,
.woocommerce .absolu-account-content .button:hover {
    background-color: var(--absolu-text);
    color: var(--absolu-white);
}

/* Edit Account form */
.absolu-account-content .edit-account {
    max-width: 520px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
}

.absolu-account-content .edit-account .form-row {
    margin: 0 0 20px;
    padding: 0;
}

.absolu-account-content .edit-account .form-row-wide {
    grid-column: 1 / -1;
}

.absolu-account-content .edit-account .form-row-first {
    grid-column: 1;
}

.absolu-account-content .edit-account .form-row-last {
    grid-column: 2;
}

.absolu-account-content .edit-account fieldset,
.absolu-account-content .edit-account .clear,
.absolu-account-content .edit-account > p:last-of-type {
    grid-column: 1 / -1;
}

.absolu-account-content .edit-account label {
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 8px;
}

.absolu-account-content .edit-account label .required {
    color: var(--absolu-primary);
}

.absolu-account-content .edit-account .input-text {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    background: var(--absolu-white);
    border-radius: 0;
    transition: border-color 0.25s ease;
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
}

.absolu-account-content .edit-account .input-text:focus {
    border-color: var(--absolu-text);
    box-shadow: none;
    outline: none;
}

.absolu-account-content .edit-account #account_display_name_description {
    display: block;
    font-size: 0.7rem;
    color: var(--absolu-text-light);
    margin-top: 6px;
}

.absolu-account-content .edit-account #account_display_name_description em {
    font-style: normal;
}

.absolu-account-content .edit-account fieldset {
    border: none;
    padding: 0;
    margin: 12px 0 20px;
}

.absolu-account-content .edit-account fieldset legend {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-text);
    padding: 16px 0;
    margin: 0;
    cursor: pointer;
}

.absolu-account-content .edit-account fieldset legend::after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-right: 1.5px solid var(--absolu-text-light);
    border-bottom: 1.5px solid var(--absolu-text-light);
    transform: rotate(45deg);
    margin-left: 8px;
    vertical-align: middle;
    transition: transform 0.2s ease;
}

.absolu-account-content .edit-account fieldset.is-open legend::after {
    transform: rotate(-135deg);
}

.absolu-account-content .edit-account fieldset .form-row {
    display: none;
}

.absolu-account-content .edit-account fieldset.is-open .form-row {
    display: block;
}

.absolu-account-content .edit-account fieldset .form-row {
    position: relative;
}

.absolu-account-content .edit-account .show-password-input {
    position: absolute;
    right: 14px;
    bottom: 14px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--absolu-text-light);
    font-size: 0;
    width: 20px;
    height: 20px;
}

.absolu-account-content .edit-account .show-password-input::after {
    font-family: 'Phosphor-Light';
    font-size: 18px;
    content: '\e220';
    color: var(--absolu-text-light);
    transition: color 0.2s ease;
}

.absolu-account-content .edit-account .show-password-input.display-password::after {
    content: '\e224';
}

.absolu-account-content .edit-account .show-password-input:hover::after {
    color: var(--absolu-text);
}

.absolu-account-content .edit-account .clear {
    display: none;
}

/* Edit address form */
.absolu-account-content .woocommerce-address-fields .woocommerce-address-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
    max-width: 520px;
}

.absolu-account-content .woocommerce-address-fields .form-row {
    margin: 0 0 20px;
    padding: 0;
}

.absolu-account-content .woocommerce-address-fields .form-row-wide {
    grid-column: 1 / -1;
}

.absolu-account-content .woocommerce-address-fields .form-row-first {
    grid-column: 1;
}

.absolu-account-content .woocommerce-address-fields .form-row-last {
    grid-column: 2;
}

.absolu-account-content .woocommerce-address-fields label {
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 8px;
}

.absolu-account-content .woocommerce-address-fields label .required {
    color: var(--absolu-primary);
}

.absolu-account-content .woocommerce-address-fields .input-text,
.absolu-account-content .woocommerce-address-fields select {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    background: var(--absolu-white);
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
    transition: border-color 0.25s ease;
}

.absolu-account-content .woocommerce-address-fields .input-text:focus,
.absolu-account-content .woocommerce-address-fields select:focus {
    border-color: var(--absolu-text);
    outline: none;
    box-shadow: none;
}

.absolu-account-content form > h2 {
    display: none;
}


.absolu-account-content .woocommerce-address-fields .clear {
    display: none;
}

/* Account payment methods */
.absolu-account-content .wc_payment_methods,
.woocommerce-account .wc_payment_methods,
.woocommerce-account .wc_payment_methods li {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-account-content .wc_payment_method,
.woocommerce-account .wc_payment_method {
    padding: 0;
    margin-bottom: 8px;
}

.absolu-account-content .wc_payment_method label,
.woocommerce-account .wc_payment_method label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--absolu-font-body);
    font-size: 0.85rem;
    color: var(--absolu-text);
    cursor: pointer;
}

.absolu-account-content .wc_payment_method input[type="radio"],
.woocommerce-account .wc_payment_method input[type="radio"],
.woocommerce-account .wc_payment_method input.input-radio {
    -webkit-appearance: none;
    appearance: none;
    width: 22px;
    height: 22px;
    min-width: 22px;
    min-height: 22px;
    border: 1px solid var(--absolu-input-active);
    border-radius: 0;
    background: none;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    display: inline-block;
    box-sizing: border-box;
    transition: border 0.15s;
}

.absolu-account-content .wc_payment_method input[type="radio"]::after,
.woocommerce-account .wc_payment_method input[type="radio"]::after,
.woocommerce-account .wc_payment_method input.input-radio::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    right: 3px;
    bottom: 3px;
    background: var(--absolu-primary);
    border-radius: 0;
    transform: scale(0);
    transition: transform 0.2s ease;
}

.absolu-account-content .wc_payment_method input[type="radio"]:checked,
.woocommerce-account .wc_payment_method input[type="radio"]:checked,
.woocommerce-account .wc_payment_method input.input-radio:checked {
    border-color: #999;
}

.absolu-account-content .wc_payment_method input[type="radio"]:checked::after,
.woocommerce-account .wc_payment_method input[type="radio"]:checked::after,
.woocommerce-account .wc_payment_method input.input-radio:checked::after {
    transform: scale(1);
}

/* Global payment method radio + list reset */
#payment .wc_payment_methods,
#payment .woocommerce-PaymentMethods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce-account #payment .wc_payment_methods li,
.woocommerce-account #payment .woocommerce-PaymentMethods li {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

#payment .wc_payment_method input[type="radio"],
#payment .wc_payment_method input.input-radio,
#payment .woocommerce-PaymentMethod input[type="radio"],
#payment .woocommerce-PaymentMethod input.input-radio {
    -webkit-appearance: none;
    appearance: none;
    width: 22px;
    height: 22px;
    min-width: 22px;
    min-height: 22px;
    border: 1px solid var(--absolu-input-active);
    border-radius: 0;
    background: none;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    display: inline-block;
    box-sizing: border-box;
    transition: border 0.15s;
}

#payment .wc_payment_method input[type="radio"]::after,
#payment .wc_payment_method input.input-radio::after,
#payment .woocommerce-PaymentMethod input[type="radio"]::after,
#payment .woocommerce-PaymentMethod input.input-radio::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    right: 3px;
    bottom: 3px;
    background: var(--absolu-primary);
    border-radius: 0;
    transform: scale(0);
    transition: transform 0.2s ease;
}

#payment .wc_payment_method input[type="radio"]:checked,
#payment .wc_payment_method input.input-radio:checked,
#payment .woocommerce-PaymentMethod input[type="radio"]:checked,
#payment .woocommerce-PaymentMethod input.input-radio:checked {
    border-color: #999;
}

#payment .wc_payment_method input[type="radio"]:checked::after,
#payment .wc_payment_method input.input-radio:checked::after,
#payment .woocommerce-PaymentMethod input[type="radio"]:checked::after,
#payment .woocommerce-PaymentMethod input.input-radio:checked::after {
    transform: scale(1);
}

#payment .wc_payment_method .payment_box,
#payment .woocommerce-PaymentMethod .payment_box {
    width: 100%;
}

#payment #place_order {
    margin-top: 20px;
}

.absolu-account-content a[href*="add-payment-method"] {
    margin-top: 20px;
    display: inline-block;
}

#payment .wc_payment_method label,
#payment .woocommerce-PaymentMethod label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--absolu-font-body);
    font-size: 0.85rem;
    color: var(--absolu-text);
    cursor: pointer;
}

/* -- Auth Cards (Login / Register) -- */

.absolu-auth {
    max-width: 440px;
    margin: 0 auto;
}

/* Auth tabs */
.absolu-auth-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--absolu-border);
    margin-bottom: 32px;
}

.absolu-auth-tab {
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 12px 24px;
    cursor: pointer;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.absolu-auth-tab:hover {
    color: var(--absolu-text);
}

.absolu-auth-tab.is-active {
    color: var(--absolu-text);
    border-bottom-color: var(--absolu-primary);
}

.absolu-auth-panel {
    display: none;
    opacity: 0;
    transform: translateY(10px);
}

.absolu-auth-panel.is-active {
    display: block;
}

.absolu-auth-panel.is-active.is-visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.absolu-auth-heading {
    font-family: var(--absolu-font);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    margin: 0 0 8px;
}

.absolu-auth-desc {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    color: var(--absolu-text-light);
    line-height: 1.6;
    margin: 0 0 28px;
}

.absolu-auth .form-row {
    margin-bottom: 20px;
}

.absolu-auth label {
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 8px;
}

.absolu-auth label .required {
    color: var(--absolu-primary);
}

.absolu-auth .input-text {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    background: var(--absolu-white);
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
    transition: border-color 0.25s ease;
}

.absolu-auth .input-text:focus {
    border-color: var(--absolu-text);
    outline: none;
    box-shadow: none;
}

.absolu-auth .woocommerce-form-login__rememberme {
    font-family: var(--absolu-font-body);
    font-size: 0.8rem;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--absolu-text-light);
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.absolu-auth .woocommerce-form-login__rememberme input[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    width: 22px;
    height: 22px;
    min-width: 22px;
    border: 1px solid var(--absolu-input-active);
    border-radius: 0;
    background: none;
    position: relative;
    cursor: pointer;
    margin: 0;
    padding: 0;
    transition: border 0.15s;
}

.absolu-auth .woocommerce-form-login__rememberme input[type="checkbox"]::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    right: 3px;
    bottom: 3px;
    background: var(--absolu-primary);
    transform: scale(0);
    transition: transform 0.2s ease;
}

.absolu-auth .woocommerce-form-login__rememberme input[type="checkbox"]:checked {
    border-color: #999;
}

.absolu-auth .woocommerce-form-login__rememberme input[type="checkbox"]:checked::after {
    transform: scale(1);
}

.absolu-auth .woocommerce-Button {
    width: 100%;
    margin-top: 8px;
    padding: 14px 24px;
    font-family: var(--absolu-font);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: var(--absolu-text);
    color: var(--absolu-white);
    border: none;
    border-radius: 0;
    cursor: pointer;
    transition: background 0.2s ease;
}

.absolu-auth .woocommerce-Button:hover {
    background: var(--absolu-primary);
}

.absolu-auth-lost {
    margin-top: 20px;
    text-align: center;
}

.absolu-auth-lost a {
    font-family: var(--absolu-font-body);
    font-size: 0.8rem;
    color: var(--absolu-text-light);
    text-decoration: none;
}

.absolu-auth-lost a:hover {
    color: var(--absolu-primary);
}

.absolu-account-auth {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    max-width: 820px;
    margin: 0 auto;
}

.absolu-auth-card {
    padding: 52px 48px;
    background: var(--absolu-white);
}

.absolu-auth-card:first-child {
    border-right: 1px solid var(--absolu-border);
}

.absolu-auth-card h2 {
    font-family: var(--absolu-font);
    font-size: 1.15rem;
    font-weight: 400;
    color: var(--absolu-text);
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}

.absolu-auth-subtitle {
    font-family: var(--absolu-font-body);
    font-size: 0.82rem;
    color: var(--absolu-text-light);
    margin: 0 0 36px;
    line-height: 1.6;
}

.absolu-auth-card .woocommerce-form label {
    font-family: var(--absolu-font);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 0;
}

.absolu-auth-card .woocommerce-form input[type="text"],
.absolu-auth-card .woocommerce-form input[type="email"],
.absolu-auth-card .woocommerce-form input[type="password"] {
    width: 100%;
    padding: 10px 0;
    border: none;
    border-bottom: 1px solid var(--absolu-border);
    border-radius: 0;
    font-family: var(--absolu-font-body);
    font-size: 0.88rem;
    color: var(--absolu-text);
    background: transparent;
    outline: none;
    transition: border-color 0.2s ease;
}

.absolu-auth-card .woocommerce-form input[type="text"]:focus,
.absolu-auth-card .woocommerce-form input[type="email"]:focus,
.absolu-auth-card .woocommerce-form input[type="password"]:focus {
    border-bottom-color: var(--absolu-text);
}

.absolu-auth-card .woocommerce-form .form-row {
    margin-bottom: 24px;
}

.absolu-auth-card .woocommerce-form button[type="submit"] {
    width: 100%;
    margin-top: 12px;
    padding: 14px 24px;
    background: var(--absolu-text);
    color: var(--absolu-white);
    border: none;
    font-family: var(--absolu-font);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s ease;
}

.absolu-auth-card .woocommerce-form button[type="submit"]:hover {
    background: var(--absolu-primary);
}

/* Remember me + lost password */
.absolu-auth-card .woocommerce-form-login__rememberme {
    font-family: var(--absolu-font-body);
    font-size: 0.78rem;
    color: var(--absolu-text-light);
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
}

.absolu-auth-card .woocommerce-LostPassword {
    margin-top: 20px;
}

.absolu-auth-card .woocommerce-LostPassword a {
    font-family: var(--absolu-font-body);
    font-size: 0.78rem;
    color: var(--absolu-text-light);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color 0.2s ease;
}

.absolu-auth-card .woocommerce-LostPassword a:hover {
    color: var(--absolu-primary);
}

/* WooCommerce login form (global fallback) */
.woocommerce-form-login .form-row,
.woocommerce-form-register .form-row,
.woocommerce-ResetPassword .form-row {
    margin-bottom: 20px;
}

.woocommerce-form-login label,
.woocommerce-form-register label,
.woocommerce-ResetPassword label {
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    display: block;
    margin-bottom: 8px;
}

.woocommerce-form-login input[type="text"],
.woocommerce-form-login input[type="email"],
.woocommerce-form-login input[type="password"],
.woocommerce-form-register input[type="text"],
.woocommerce-form-register input[type="email"],
.woocommerce-form-register input[type="password"],
.woocommerce-ResetPassword input[type="text"],
.woocommerce-ResetPassword input[type="email"] {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--absolu-border);
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    background: var(--absolu-white);
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
    transition: border-color 0.25s ease;
}

.woocommerce-form-login input:focus,
.woocommerce-form-register input:focus,
.woocommerce-ResetPassword input:focus {
    border-color: var(--absolu-text);
    outline: none;
    box-shadow: none;
}

.woocommerce-form-login .show-password-input {
    position: relative;
    top: -34px;
    float: right;
    margin-right: 14px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0;
    width: 20px;
    height: 20px;
}

.woocommerce-form-login .show-password-input::after {
    font-family: 'Phosphor-Light';
    font-size: 18px;
    content: '\e220';
    color: var(--absolu-text-light);
}

.woocommerce-form-login .show-password-input.display-password::after {
    content: '\e224';
}

.woocommerce-form-login .woocommerce-form-login__rememberme {
    font-family: var(--absolu-font-body);
    font-size: 0.8rem;
    color: var(--absolu-text-light);
    display: flex;
    align-items: center;
    gap: 8px;
}

/* WooCommerce notices */
.woocommerce-error,
.woocommerce-message,
.woocommerce-info {
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    padding: 16px 20px;
    margin-bottom: 24px;
    list-style: none;
    border: none;
    outline: none;
}

.woocommerce-message {
    background: #f0f9f2;
    color: var(--absolu-success);
}

.woocommerce-error {
    background: #fdf2f2;
    color: var(--absolu-error);
}

.woocommerce-info {
    background: var(--absolu-bg-light);
    color: var(--absolu-text);
}

li.woocommerce-error,
li.woocommerce-message,
li.woocommerce-info {
    margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   19. Responsive (new pages)
   -------------------------------------------------------------------------- */

@media (max-width: 1024px) {
    .absolu-product-grid--shop {
        grid-template-columns: repeat(4, 1fr);
    }

    .absolu-product-grid--related {
        grid-template-columns: repeat(3, 1fr);
    }

    .absolu-sp-layout {
        gap: 32px;
    }

    .absolu-sp-gallery {
        position: static;
        grid-template-columns: 1fr;
    }

    .absolu-sp-gallery__thumbs {
        flex-direction: row;
        overflow-x: auto;
        overflow-y: visible;
        max-height: none;
        order: 2;
    }

    .absolu-sp-gallery__main {
        order: 1;
    }

    .absolu-sp-trust {
        flex-wrap: wrap;
        gap: 12px;
    }

    .absolu-checkout-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .absolu-checkout-sidebar {
        position: static;
    }

    .absolu-account-layout {
        grid-template-columns: 180px 1fr;
    }

    .absolu-account-nav {
        padding-right: 32px;
    }

    .absolu-account-content {
        padding-left: 32px;
    }
}

@media (max-width: 768px) {
    .absolu-page {
        padding: 50px 0;
    }

    .absolu-page-title {
        font-size: 1.75rem;
    }

    .absolu-archive-header {
        padding: 4px 0 24px;
    }

    .absolu-archive-header__title {
        font-size: 24px;
    }

    .absolu-sp-layout {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .absolu-sp-gallery {
        position: static;
        grid-template-columns: 1fr;
    }

    .absolu-sp-gallery__thumbs {
        flex-direction: row;
        overflow-x: auto;
        overflow-y: visible;
        max-height: none;
        order: 2;
    }

    .absolu-sp-gallery__main {
        order: 1;
    }

    .absolu-sp-gallery__img {
        aspect-ratio: 1 / 1;
    }

    .absolu-sp-trust {
        flex-direction: column;
        gap: 10px;
    }

    .absolu-sp-actions {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 10px;
    }

    .absolu-sp-form {
        display: contents;
    }

    .absolu-sp-qty {
        order: 1;
        width: fit-content;
    }

    .absolu-sp-wishlist {
        order: 2;
        width: 52px;
        height: 52px;
    }

    .absolu-sp-atc {
        order: 3;
        width: 100%;
        height: 52px;
        justify-content: center;
        margin-top: 2px;
    }

    .absolu-product-grid--shop,
    .absolu-product-grid--related {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

    /* Cart mobile */
    .absolu-page--cart .woocommerce {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .absolu-cart-table thead {
        display: none;
    }

    .absolu-cart-table tbody .absolu-cart-item {
        display: grid;
        grid-template-columns: 80px 1fr;
        gap: 4px 16px;
        padding: 20px 0;
        border-bottom: 1px solid var(--absolu-border);
        position: relative;
    }

    .absolu-cart-item td {
        padding: 2px 0;
        border: none;
    }

    .absolu-cart-item__img {
        grid-row: 1 / 5;
        width: auto;
        padding: 0;
    }

    .absolu-cart-item__img img {
        width: 80px;
        height: 80px;
    }

    .absolu-cart-item__name {
        grid-column: 2;
        padding-right: 32px;
    }

    .absolu-cart-item__price {
        grid-column: 2;
        font-size: 0.8125rem;
    }

    .absolu-cart-item__qty {
        grid-column: 2;
        text-align: left;
    }

    .absolu-cart-item__total {
        display: none;
    }

    .absolu-cart-item__remove {
        position: absolute;
        top: 20px;
        right: 0;
        width: auto;
    }

    .absolu-cart-actions {
        flex-wrap: wrap;
    }

    .absolu-cart-totals {
        padding: 28px 20px;
        position: static;
    }

    /* Checkout mobile */
    .absolu-checkout-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .absolu-checkout-sidebar {
        position: static;
    }

    .absolu-checkout-order {
        padding: 28px 20px;
    }

    .absolu-checkout-section .woocommerce-billing-fields__field-wrapper,
    .absolu-checkout-section .woocommerce-shipping-fields__field-wrapper,
    .absolu-checkout-section .woocommerce-additional-fields__field-wrapper {
        grid-template-columns: 1fr;
    }

    .absolu-checkout-section .form-row-first,
    .absolu-checkout-section .form-row-last {
        grid-column: 1;
    }

    /* Account mobile */
    .absolu-account-layout {
        grid-template-columns: 1fr;
    }

    .absolu-account-nav {
        border-right: none;
        border-bottom: 1px solid var(--absolu-border);
        padding-right: 0;
        padding-bottom: 0;
        margin-bottom: 32px;
        overflow: hidden;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation ul {
        display: flex;
        flex-wrap: nowrap;
        gap: 0;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 0;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
        display: none;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation li {
        flex-shrink: 0;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation li a {
        padding: 12px 16px;
        font-size: 0.7rem;
        border: none;
        border-bottom: 2px solid transparent;
        white-space: nowrap;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation li a:hover {
        border-bottom-color: var(--absolu-text-light);
    }

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

    .absolu-account-content {
        padding-left: 0;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation-link--customer-logout {
        margin-top: 0;
        padding-top: 0;
        border-top: none;
    }

    /* Dashboard stats */
    .absolu-dashboard__stats {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .absolu-dashboard__stat {
        padding: 16px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        text-align: left;
    }

    .absolu-dashboard__stat-value {
        font-size: 1rem;
        margin-bottom: 0;
    }

    .absolu-dashboard__section-header {
        flex-direction: row;
    }

    /* Dashboard orders table */
    .absolu-dashboard__orders thead {
        display: none;
    }

    .absolu-dashboard__orders tr {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 4px;
        padding: 14px 0;
        border-bottom: 1px solid var(--absolu-border);
    }

    .absolu-dashboard__orders td {
        padding: 2px 0;
        border: none;
    }

    /* Account orders table */
    .absolu-account-content table {
        font-size: 0.78rem;
    }

    .absolu-account-content table th,
    .absolu-account-content table td {
        padding: 10px 8px;
        font-size: 0.75rem;
    }

    /* Edit account & address forms */
    .absolu-account-content .edit-account,
    .absolu-account-content .woocommerce-address-fields .woocommerce-address-fields__field-wrapper {
        grid-template-columns: 1fr;
        max-width: 100%;
    }

    .absolu-account-content .edit-account .form-row-first,
    .absolu-account-content .edit-account .form-row-last,
    .absolu-account-content .woocommerce-address-fields .form-row-first,
    .absolu-account-content .woocommerce-address-fields .form-row-last {
        grid-column: 1;
    }

    /* Address page */
    .absolu-account-content .woocommerce-Address-title {
        flex-wrap: wrap;
        gap: 8px;
    }

    /* Auth forms */
    .absolu-auth {
        max-width: 100%;
        padding: 0;
    }

    .absolu-auth-tabs {
        margin-bottom: 24px;
    }

    .absolu-auth-tab {
        padding: 10px 16px;
        font-size: 0.7rem;
    }

    .absolu-account-auth {
        grid-template-columns: 1fr;
    }

    .absolu-auth-card:first-child {
        border-right: none;
        border-bottom: 1px solid var(--absolu-border);
    }

    .absolu-auth-card {
        padding: 36px 24px;
    }

    /* View order stat boxes */
    .absolu-account-content .absolu-dashboard__stats {
        grid-template-columns: 1fr;
    }


    /* WhatsApp float mobile */
    .absolu-whatsapp-float {
        bottom: 20px;
        right: 20px;
        width: 50px;
        height: 50px;
    }

    .absolu-whatsapp-float i {
        font-size: 24px;
    }

    /* Shop filters mobile */
    .absolu-shop-filters {
        flex-wrap: wrap;
        gap: 12px;
    }

    .absolu-filters {
        width: 100%;
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .absolu-filters::-webkit-scrollbar {
        display: none;
    }
}

@media (max-width: 480px) {
    .absolu-product-grid--shop {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .absolu-product-grid--related {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .absolu-sp-gallery__thumbs {
        gap: 4px;
    }

    .absolu-sp-gallery__thumb {
        width: 56px;
        height: 56px;
    }

    /* Account 480px */
    .absolu-account-nav .woocommerce-MyAccount-navigation li a {
        padding: 10px 12px;
        font-size: 0.65rem;
    }

    .absolu-account-nav .woocommerce-MyAccount-navigation li a::before {
        font-size: 14px;
    }

    .absolu-account-content table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .absolu-dashboard__greeting {
        font-size: 0.88rem;
    }

    .absolu-checkout-order {
        padding: 20px 16px;
    }

    .absolu-auth-tab {
        padding: 10px 12px;
        font-size: 0.65rem;
    }
}

/* --------------------------------------------------------------------------
   20. Utility
   -------------------------------------------------------------------------- */

.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

/* --------------------------------------------------------------------------
   21. About Us Page
   -------------------------------------------------------------------------- */

/* -- Eyebrow Label -- */

.about-eyebrow {
    display: block;
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--absolu-secondary);
    margin-bottom: 16px;
}

/* -- Hero -- */

.about-hero {
    padding: 140px 0 120px;
    background: var(--absolu-white);
    text-align: center;
    border-bottom: 1px solid var(--absolu-border);
}

.about-hero__inner {
    max-width: 720px;
    margin: 0 auto;
}

.about-hero__eyebrow {
    display: block;
    font-family: var(--absolu-font);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--absolu-secondary);
    margin-bottom: 28px;
}

.about-hero__title {
    font-family: var(--absolu-font);
    font-size: clamp(2.5rem, 5vw, 3.75rem);
    font-weight: 300;
    color: var(--absolu-text);
    line-height: 1.15;
    letter-spacing: -0.015em;
    margin: 0 0 32px;
}

.about-hero__rule {
    width: 48px;
    height: 1px;
    background: var(--absolu-primary);
    margin: 0 auto 32px;
}

.about-hero__text {
    font-family: var(--absolu-font-body);
    font-size: 1rem;
    line-height: 1.9;
    color: var(--absolu-text-light);
    max-width: 540px;
    margin: 0 auto;
}

/* -- Story -- */

.about-story {
    padding: 120px 0;
    background: var(--absolu-white);
}

.about-story__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 100px;
    align-items: start;
}

.about-story__left {
    position: sticky;
    top: 120px;
}

.about-story__title {
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--absolu-text);
    margin: 0;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.about-story__right p {
    font-family: var(--absolu-font-body);
    font-size: 0.92rem;
    line-height: 1.95;
    color: var(--absolu-text-light);
    margin: 0 0 24px;
}

.about-story__right p:last-child {
    margin-bottom: 0;
}

/* -- Stats -- */

.about-stats {
    padding: 72px 0;
    background: var(--absolu-white);
    border-top: 1px solid var(--absolu-border);
    border-bottom: 1px solid var(--absolu-border);
}

.about-stats__row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    text-align: center;
}

.about-stats__item {
    padding: 16px 24px;
    position: relative;
}

.about-stats__item+.about-stats__item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 48px;
    background: var(--absolu-border);
}

.about-stats__number {
    display: block;
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--absolu-primary);
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 10px;
}

.about-stats__label {
    display: block;
    font-family: var(--absolu-font-body);
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
}

/* -- Values -- */

.about-values {
    padding: 120px 0;
    background: var(--absolu-white);
}

.about-values__header {
    margin-bottom: 72px;
}

.about-values__title {
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--absolu-text);
    margin: 0;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.about-values__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

.about-values__card {
    padding: 48px 40px;
    border-left: 1px solid var(--absolu-border);
    position: relative;
}

.about-values__card:first-child {
    border-left: none;
    padding-left: 0;
}

.about-values__card:last-child {
    padding-right: 0;
}

.about-values__num {
    display: block;
    font-family: var(--absolu-font);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--absolu-secondary);
    margin-bottom: 24px;
}

.about-values__card-title {
    font-family: var(--absolu-font);
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--absolu-text);
    margin: 0 0 16px;
    letter-spacing: -0.01em;
}

.about-values__card p {
    font-family: var(--absolu-font-body);
    font-size: 0.88rem;
    line-height: 1.85;
    color: var(--absolu-text-light);
    margin: 0;
}

/* -- Why Choose Us -- */

.about-why {
    padding: 120px 0;
    background: var(--absolu-bg-light);
}

.about-why__header {
    text-align: center;
    margin-bottom: 72px;
}

.about-why__title {
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--absolu-text);
    margin: 0;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.about-why__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 48px;
    max-width: 1200px;
    margin: 0 auto;
}

.about-why__item {
    text-align: center;
}

.about-why__icon-wrap {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    border: 1px solid var(--absolu-border);
    border-radius: 50%;
    background: var(--absolu-white);
    transition: border-color 0.3s ease;
}

.about-why__item:hover .about-why__icon-wrap {
    border-color: var(--absolu-text);
}

.about-why__icon-wrap i {
    font-size: 1.2rem;
    color: var(--absolu-text);
}

.about-why__item h3 {
    font-family: var(--absolu-font);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--absolu-text);
    margin: 0 0 10px;
    letter-spacing: -0.01em;
}

.about-why__item p {
    font-family: var(--absolu-font-body);
    font-size: 0.84rem;
    line-height: 1.8;
    color: var(--absolu-text-light);
    margin: 0;
}

/* -- CTA -- */

.about-cta {
    padding: 120px 0;
    background: var(--absolu-white);
    text-align: center;
    border-top: 1px solid var(--absolu-border);
}

.about-cta__inner {
    max-width: 560px;
    margin: 0 auto;
}

.about-cta__title {
    font-family: var(--absolu-font);
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 300;
    color: var(--absolu-text);
    margin: 0 0 20px;
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.about-cta__text {
    font-family: var(--absolu-font-body);
    font-size: 0.92rem;
    line-height: 1.85;
    color: var(--absolu-text-light);
    margin: 0 0 44px;
}

.about-cta__btn {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--absolu-white);
    border: 1px solid var(--absolu-primary);
    padding: 16px 48px;
    text-decoration: none;
    background: var(--absolu-primary);
    transition: background 0.3s ease, border-color 0.3s ease;
}

.about-cta__btn:hover {
    background: var(--absolu-primary-dark);
    border-color: var(--absolu-primary-dark);
    color: var(--absolu-white);
}

/* -- About Responsive -- */

@media (max-width: 1024px) {
    .about-hero {
        padding: 120px 0 100px;
    }

    .about-story__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .about-story__left {
        position: static;
    }

    .about-story__title br {
        display: none;
    }

    .about-values__grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .about-values__card {
        border-left: none;
        border-top: 1px solid var(--absolu-border);
        padding: 40px 0;
    }

    .about-values__card:first-child {
        border-top: none;
        padding-top: 0;
    }

    .about-values__card:last-child {
        padding-bottom: 0;
    }

    .about-why__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 40px;
    }
}

@media (max-width: 768px) {
    .about-hero {
        padding: 100px 0 80px;
    }

    .about-hero__title {
        font-size: clamp(2rem, 6vw, 2.5rem);
    }

    .about-hero__title br {
        display: none;
    }

    .about-hero__text {
        font-size: 0.92rem;
    }

    .about-story {
        padding: 72px 0;
    }

    .about-story__right p {
        font-size: 0.88rem;
    }

    .about-stats {
        padding: 56px 0;
    }

    .about-stats__row {
        grid-template-columns: repeat(2, 1fr);
        gap: 32px 0;
    }

    .about-stats__item+.about-stats__item::before {
        display: none;
    }

    .about-stats__item:nth-child(2)::before,
    .about-stats__item:nth-child(4)::before {
        display: block;
    }

    .about-values {
        padding: 72px 0;
    }

    .about-values__title br {
        display: none;
    }

    .about-values__header {
        margin-bottom: 48px;
    }

    .about-why {
        padding: 72px 0;
    }

    .about-why__grid {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .about-cta {
        padding: 72px 0;
    }

    .about-cta__text {
        font-size: 0.88rem;
    }
}

@media (max-width: 480px) {
    .about-hero {
        padding: 80px 0 64px;
    }

    .about-hero__title {
        font-size: 1.75rem;
        line-height: 1.25;
    }

    .about-hero__eyebrow {
        font-size: 0.6rem;
        letter-spacing: 0.2em;
    }

    .about-hero__text {
        font-size: 0.88rem;
        line-height: 1.8;
    }

    .about-story {
        padding: 56px 0;
    }

    .about-story__title {
        font-size: 1.5rem;
    }

    .about-story__right p {
        font-size: 0.85rem;
        margin-bottom: 20px;
    }

    .about-stats {
        padding: 48px 0;
    }

    .about-stats__row {
        grid-template-columns: 1fr 1fr;
        gap: 24px 0;
    }

    .about-stats__number {
        font-size: 1.5rem;
    }

    .about-stats__label {
        font-size: 0.65rem;
    }

    .about-values {
        padding: 56px 0;
    }

    .about-values__title {
        font-size: 1.5rem;
    }

    .about-values__header {
        margin-bottom: 40px;
    }

    .about-values__card {
        padding: 32px 0;
    }

    .about-values__card-title {
        font-size: 1rem;
    }

    .about-values__card p {
        font-size: 0.84rem;
    }

    .about-why {
        padding: 56px 0;
    }

    .about-why__title {
        font-size: 1.5rem;
    }

    .about-why__header {
        margin-bottom: 48px;
    }

    .about-why__grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .about-why__item h3 {
        font-size: 0.9rem;
    }

    .about-why__item p {
        font-size: 0.8rem;
    }

    .about-cta {
        padding: 64px 0;
    }

    .about-cta__title {
        font-size: 1.5rem;
    }

    .about-cta__text {
        font-size: 0.84rem;
        margin-bottom: 36px;
    }

    .about-cta__btn {
        padding: 14px 36px;
        font-size: 0.68rem;
    }
}

/* --------------------------------------------------------------------------
   21b. Wholesale Page
   -------------------------------------------------------------------------- */

.wholesale-page {
    padding: 100px 0 120px;
    background: var(--absolu-white);
}

.wholesale-page__title {
    font-family: var(--absolu-font);
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--absolu-text);
    letter-spacing: 0.04em;
    margin: 0 0 40px;
}

.wholesale-page__body {
    max-width: 620px;
}

.wholesale-page__body p {
    font-family: var(--absolu-font-body);
    font-size: 0.92rem;
    line-height: 1.85;
    color: var(--absolu-text-light);
    margin: 0 0 20px;
}

.wholesale-page__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--absolu-font);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--absolu-white);
    background: #25D366;
    border: 1px solid #25D366;
    padding: 14px 40px;
    text-decoration: none;
    margin-top: 20px;
    transition: background 0.3s ease, border-color 0.3s ease;
}

.wholesale-page__btn i {
    font-size: 1.1rem;
}

.wholesale-page__btn:hover {
    background: #1da851;
    border-color: #1da851;
    color: var(--absolu-white);
}

@media (max-width: 1024px) {
    .wholesale-page {
        padding: 80px 0 96px;
    }
}

@media (max-width: 767px) {
    .wholesale-page {
        padding: 72px 0 80px;
    }

    .wholesale-page__title {
        font-size: 1.25rem;
    }

    .wholesale-page__body p {
        font-size: 0.88rem;
    }

    .wholesale-page__btn {
        padding: 13px 32px;
        font-size: 0.68rem;
        width: 100%;
        justify-content: center;
    }
}

/* --------------------------------------------------------------------------
   22. Wishlist
   -------------------------------------------------------------------------- */

.absolu-wishlist-count {
    display: none;
}

/* Wishlist page */

.absolu-wishlist-grid {
    grid-template-columns: repeat(4, 1fr);
}

.absolu-wishlist-empty {
    text-align: center;
    padding: 80px 20px;
}

.absolu-wishlist-empty p {
    font-family: var(--absolu-font-body);
    font-size: 0.95rem;
    color: var(--absolu-text-light);
    margin: 0 0 28px;
}

.absolu-wishlist-empty__btn {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--absolu-white);
    background: var(--absolu-text);
    padding: 14px 40px;
    text-decoration: none;
    transition: background 0.2s ease;
}

.absolu-wishlist-empty__btn:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

.absolu-wishlist-loading {
    text-align: center;
    padding: 60px 20px;
    font-family: var(--absolu-font-body);
    font-size: 0.9rem;
    color: var(--absolu-text-light);
}

@media (max-width: 1024px) {
    .absolu-wishlist-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .absolu-wishlist-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .absolu-sp-wishlist {
        font-size: 0.78rem;
        padding: 10px 20px;
    }
}

@media (max-width: 480px) {
    .absolu-wishlist-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .absolu-wishlist-empty {
        padding: 56px 16px;
    }
}

/* --------------------------------------------------------------------------
   LIVE SEARCH OVERLAY
   -------------------------------------------------------------------------- */
.absolu-live-search {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.absolu-live-search.is-active {
    opacity: 1;
    visibility: visible;
}

.absolu-live-search__panel {
    width: 100%;
    max-width: 1200px;
    padding: 24px 40px 40px;
    max-height: 100%;
    overflow-y: auto;
}

.absolu-live-search__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 32px;
}

.absolu-live-search__count {
    font-family: var(--absolu-font-body);
    font-size: 14px;
    color: var(--absolu-text-light);
    letter-spacing: 0.02em;
}

.absolu-live-search__close {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 24px;
    color: var(--absolu-text-light);
    padding: 0;
    transition: color 0.2s ease;
}

.absolu-live-search__close:hover {
    color: var(--absolu-text);
}

/* Results grid */
.absolu-live-search__results {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 24px;
}

.absolu-live-search__empty {
    grid-column: 1 / -1;
    text-align: center;
    font-family: var(--absolu-font-body);
    font-size: 15px;
    color: var(--absolu-text-light);
    padding: 60px 0;
}

.absolu-live-search__view-all {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    padding: 8px 0 0;
}

.absolu-live-search__view-all a {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--absolu-white);
    background: var(--absolu-text);
    padding: 12px 40px;
    text-decoration: none;
    transition: background 0.2s ease;
}

.absolu-live-search__view-all a:hover {
    background: var(--absolu-primary);
}

@media (max-width: 1024px) {
    .absolu-live-search__results {
        grid-template-columns: repeat(3, 1fr);
    }

    .absolu-live-search__panel {
        padding: 60px 24px 24px;
    }
}

@media (max-width: 768px) {
    .absolu-live-search__results {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

    .absolu-live-search__panel {
        padding: 48px 16px 16px;
    }
}

/* --------------------------------------------------------------------------
   Shipping Methods (Checkout & Cart)
   -------------------------------------------------------------------------- */

/* Shipping methods list -- checkout sidebar */
.absolu-checkout-order .woocommerce-shipping-methods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.absolu-checkout-order .woocommerce-shipping-methods li {
    padding: 14px 0;
    border-bottom: 1px solid var(--absolu-border);
    display: flex;
    align-items: center;
    gap: 12px;
    transition: opacity 0.2s ease;
}

.absolu-checkout-order .woocommerce-shipping-methods li:last-child {
    border-bottom: none;
}

/* Hide native radio */
.woocommerce-shipping-methods input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

/* Custom radio indicator */
.woocommerce-shipping-methods label {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    cursor: pointer;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    font-weight: 400;
    color: var(--absolu-text);
    line-height: 1.4;
    position: relative;
}

.woocommerce-shipping-methods label::before {
    content: '';
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    border: 1.5px solid #999;
    border-radius: 50%;
    position: relative;
    transition: border-color 0.2s ease;
}

.woocommerce-shipping-methods label::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 50%;
    transform: translateY(-50%) scale(0);
    width: 10px;
    height: 10px;
    background: var(--absolu-primary);
    border-radius: 50%;
    transition: transform 0.2s ease;
}

.woocommerce-shipping-methods input[type="radio"]:checked+label::before {
    border-color: var(--absolu-primary);
}

.woocommerce-shipping-methods input[type="radio"]:checked+label::after {
    transform: translateY(-50%) scale(1);
}

/* Price amount -- pushed right */
.woocommerce-shipping-methods label .woocommerce-Price-amount,
.woocommerce-shipping-methods label .amount {
    margin-left: auto;
    font-weight: 500;
    white-space: nowrap;
    color: var(--absolu-text);
}

/* Shipping row in checkout order table */
.absolu-checkout-order .woocommerce-checkout-review-order-table .woocommerce-shipping-totals th {
    font-family: var(--absolu-font);
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    vertical-align: middle;
    padding-top: 16px;
    white-space: nowrap;
    width: 1%;
    padding-right: 16px;
}

.absolu-checkout-order .woocommerce-checkout-review-order-table .woocommerce-shipping-totals td {
    text-align: left;
    vertical-align: middle;
    padding-top: 12px;
}

/* "Calculating..." text */
.woocommerce-shipping-methods .shipping-calculator-button,
.woocommerce-shipping-totals .woocommerce-shipping-calculator {
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    color: var(--absolu-text-light);
}

/* Processing / loading state */
.processing .woocommerce-shipping-methods,
.blockOverlay~.woocommerce-shipping-methods {
    opacity: 0.4;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

@keyframes absolu-shimmer {
    0% {
        background-position: -200% 0;
    }

    100% {
        background-position: 200% 0;
    }
}

.processing .woocommerce-shipping-totals td::before {
    content: '';
    display: block;
    height: 2px;
    margin-bottom: 8px;
    background: linear-gradient(90deg, var(--absolu-border) 25%, var(--absolu-secondary-light) 50%, var(--absolu-border) 75%);
    background-size: 200% 100%;
    animation: absolu-shimmer 1.5s ease infinite;
    border-radius: 1px;
}

/* Cart page shipping -- inherit same radio style */
.absolu-totals-table .woocommerce-shipping-totals td {
    text-align: right;
}

.absolu-totals-table .woocommerce-shipping-methods {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
}

.absolu-totals-table .woocommerce-shipping-methods li {
    padding: 6px 0;
    display: flex;
    align-items: center;
}

.absolu-totals-table .woocommerce-shipping-methods label {
    font-size: 0.8125rem;
    font-weight: 400;
    color: var(--absolu-text);
}

/* Single shipping method -- hide radio, just show text */
.woocommerce-shipping-methods li:only-child input[type="radio"],
.woocommerce-shipping-methods li:only-child label::before,
.woocommerce-shipping-methods li:only-child label::after {
    display: none;
}

.woocommerce-shipping-methods li:only-child label {
    padding-left: 0;
    cursor: default;
}

/* Mobile */
@media (max-width: 768px) {
    .absolu-checkout-order .woocommerce-shipping-methods li {
        padding: 12px 0;
    }
}

@media (max-width: 480px) {
    .absolu-live-search__results {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
}

/* --------------------------------------------------------------------------
   Place Order -- Processing State
   -------------------------------------------------------------------------- */

/* blockUI overlay (WC AJAX updates) */
.absolu-checkout .blockUI.blockOverlay {
    background: var(--absolu-white) !important;
    opacity: 0.6 !important;
    cursor: default !important;
}

/* Remove WC default loading gif */
.absolu-checkout .loader,
.absolu-checkout .blockUI.blockMsg {
    display: none !important;
}

/* Processing state on checkout form */
.absolu-checkout.processing #place_order {
    pointer-events: none;
    opacity: 0.7;
    position: relative;
    color: transparent;
}

.absolu-checkout.processing #place_order::after {
    content: 'Processing...';
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: var(--absolu-white);
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

@keyframes absolu-btn-pulse {

    0%,
    100% {
        opacity: 0.7;
    }

    50% {
        opacity: 0.5;
    }
}

.absolu-checkout.processing #place_order {
    animation: absolu-btn-pulse 1.5s ease infinite;
}

/* --------------------------------------------------------------------------
   Thank You / Order Confirmation
   -------------------------------------------------------------------------- */

.absolu-thankyou {
    max-width: 900px;
    margin: 0 auto;
    padding: 0;
}

/* -- Header -- */
.absolu-thankyou__header {
    text-align: center;
    margin-bottom: 56px;
    animation: absolu-checkout-fade-up 0.5s ease both;
}

/* Animated checkmark */
.absolu-thankyou__icon {
    margin: 0 auto 28px;
    width: 64px;
    height: 64px;
}

.absolu-thankyou__check {
    width: 64px;
    height: 64px;
}

.absolu-thankyou__check-circle {
    stroke: #2e7d32;
    stroke-width: 2;
    stroke-dasharray: 166;
    stroke-dashoffset: 166;
    animation: absolu-check-circle 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

.absolu-thankyou__check-mark {
    stroke: #2e7d32;
    stroke-width: 2.5;
    stroke-dasharray: 48;
    stroke-dashoffset: 48;
    animation: absolu-check-mark 0.35s cubic-bezier(0.65, 0, 0.45, 1) 0.5s forwards;
}

@keyframes absolu-check-circle {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes absolu-check-mark {
    to {
        stroke-dashoffset: 0;
    }
}

/* Failed icon */
.absolu-thankyou__icon--failed {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--absolu-primary);
    border-radius: 50%;
    color: var(--absolu-primary);
}

.absolu-thankyou__title {
    font-family: var(--absolu-font);
    font-size: 1.75rem;
    font-weight: 400;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--absolu-text);
    margin: 0 0 10px;
}

.absolu-thankyou__subtitle {
    font-family: var(--absolu-font-body);
    font-size: 0.9375rem;
    color: var(--absolu-text-light);
    margin: 0 0 16px;
    font-weight: 300;
}

.absolu-thankyou__order-num {
    display: inline-block;
    font-family: var(--absolu-font);
    font-size: 0.8125rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text);
    margin: 8px 0 0;
    padding: 10px 24px;
    border: 1px solid var(--absolu-border);
    background: var(--absolu-bg-light);
}

/* -- Two-column grid -- */
.absolu-thankyou__grid {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 60px;
    margin-bottom: 48px;
    animation: absolu-checkout-fade-up 0.5s ease both;
    animation-delay: 0.15s;
}

.absolu-thankyou__section h3 {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    margin: 0 0 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--absolu-border);
}

/* Items list */
.absolu-thankyou__items-list {
    margin-bottom: 20px;
}

.absolu-thankyou__item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 10px 0;
    border-bottom: 1px solid var(--absolu-border);
    gap: 24px;
}

.absolu-thankyou__item:last-child {
    border-bottom: none;
}

.absolu-thankyou__item-info {
    flex: 1;
    min-width: 0;
}

.absolu-thankyou__item-name {
    display: block;
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    color: var(--absolu-text);
    line-height: 1.4;
}

.absolu-thankyou__item-qty {
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    color: #aaa;
    margin-top: 2px;
    display: block;
}

.absolu-thankyou__item-price {
    font-family: var(--absolu-font-body);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--absolu-text);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Totals */
.absolu-thankyou__totals {
    border-top: 1px solid var(--absolu-border);
    padding-top: 12px;
}

.absolu-thankyou__totals-row {
    display: flex;
    justify-content: space-between;
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    color: var(--absolu-text-light);
    padding: 5px 0;
}

.absolu-thankyou__totals-row span:last-child {
    font-weight: 500;
    color: var(--absolu-text);
}

.absolu-thankyou__totals-total {
    border-top: 2px solid var(--absolu-text);
    margin-top: 10px;
    padding-top: 14px;
    font-family: var(--absolu-font);
    font-size: 1rem;
    font-weight: 700;
    color: var(--absolu-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.absolu-thankyou__totals-total span:last-child {
    font-family: var(--absolu-font);
    font-weight: 700;
    color: var(--absolu-text);
}

/* -- Right column: details -- */
.absolu-thankyou__details h3 {
    margin-top: 28px;
}

.absolu-thankyou__details h3:first-child {
    margin-top: 0;
}

.absolu-thankyou__address {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    font-style: normal;
    color: var(--absolu-text);
    line-height: 1.7;
}

.absolu-thankyou__payment,
.absolu-thankyou__date {
    font-family: var(--absolu-font-body);
    font-size: 0.8125rem;
    color: var(--absolu-text);
    margin: 0;
}

/* -- Timeline -- */
.absolu-thankyou__timeline {
    margin-bottom: 48px;
    animation: absolu-checkout-fade-up 0.5s ease both;
    animation-delay: 0.3s;
}

.absolu-thankyou__timeline h3 {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--absolu-text-light);
    margin: 0 0 24px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--absolu-border);
}

.absolu-thankyou__steps {
    display: flex;
    gap: 0;
}

.absolu-thankyou__step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
}

/* Connecting line between dots */
.absolu-thankyou__step:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 7px;
    left: calc(50% + 12px);
    width: calc(100% - 24px);
    height: 1px;
    background: var(--absolu-border);
}

.absolu-thankyou__step--active:not(:last-child)::after {
    background: var(--absolu-secondary);
}

.absolu-thankyou__step-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 1.5px solid var(--absolu-border);
    background: var(--absolu-white);
    margin-bottom: 12px;
    position: relative;
    z-index: 1;
}

.absolu-thankyou__step--active .absolu-thankyou__step-dot {
    border-color: var(--absolu-secondary);
    background: var(--absolu-secondary);
}

.absolu-thankyou__step-title {
    display: block;
    font-family: var(--absolu-font-body);
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--absolu-text);
    margin-bottom: 4px;
}

.absolu-thankyou__step-desc {
    display: block;
    font-family: var(--absolu-font-body);
    font-size: 0.6875rem;
    color: #aaa;
    line-height: 1.4;
}

/* -- Action buttons -- */
.absolu-thankyou__actions {
    display: flex;
    justify-content: center;
    gap: 16px;
    animation: absolu-checkout-fade-up 0.5s ease both;
    animation-delay: 0.4s;
}

.absolu-thankyou__btn {
    font-family: var(--absolu-font);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 16px 40px;
    text-decoration: none;
    transition: background 0.25s ease, color 0.25s ease;
    text-align: center;
}

.absolu-thankyou__btn--primary {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

.absolu-thankyou__btn--primary:hover {
    background: var(--absolu-primary);
    color: var(--absolu-white);
}

.absolu-thankyou__btn--outline {
    background: transparent;
    color: var(--absolu-text);
    border: 1px solid var(--absolu-text);
}

.absolu-thankyou__btn--outline:hover {
    background: var(--absolu-text);
    color: var(--absolu-white);
}

/* -- Tablet -- */
@media (max-width: 1024px) {
    .absolu-thankyou__grid {
        grid-template-columns: 1fr;
        gap: 36px;
    }
}

/* -- Mobile -- */
@media (max-width: 768px) {
    .absolu-thankyou__header {
        margin-bottom: 36px;
    }

    .absolu-thankyou__icon {
        width: 52px;
        height: 52px;
        margin-bottom: 20px;
    }

    .absolu-thankyou__check {
        width: 52px;
        height: 52px;
    }

    .absolu-thankyou__title {
        font-size: 1.125rem;
        letter-spacing: 0.04em;
    }

    .absolu-thankyou__subtitle {
        font-size: 0.8125rem;
    }

    .absolu-thankyou__order-num {
        font-size: 0.6875rem;
        padding: 8px 18px;
    }

    .absolu-thankyou__grid {
        grid-template-columns: 1fr;
        gap: 28px;
        margin-bottom: 36px;
    }

    .absolu-thankyou__item {
        padding: 8px 0;
    }

    .absolu-thankyou__item-name {
        font-size: 0.8125rem;
    }

    .absolu-thankyou__item-price {
        font-size: 0.8125rem;
    }

    .absolu-thankyou__steps {
        flex-direction: column;
        gap: 0;
        align-items: flex-start;
        padding-left: 6px;
    }

    .absolu-thankyou__step {
        flex-direction: row;
        text-align: left;
        gap: 16px;
        padding: 12px 0;
    }

    .absolu-thankyou__step-dot {
        margin-bottom: 0;
        flex-shrink: 0;
        margin-top: 2px;
    }

    .absolu-thankyou__step:not(:last-child)::after {
        top: 26px;
        left: 6px;
        width: 1px;
        height: calc(100% - 14px);
    }

    .absolu-thankyou__timeline {
        margin-bottom: 36px;
    }

    .absolu-thankyou__actions {
        flex-direction: column;
    }

    .absolu-thankyou__btn {
        width: 100%;
        padding: 14px 20px;
    }
}