/* Route-scoped visual fixes from the frozen 2026-04-15 audit. */

.page-shell {
    padding-top: clamp(2.5rem, 5vw, 4rem);
}

.content-page-card--document {
    max-width: 62rem;
    margin-inline: auto;
    padding: clamp(1.5rem, 3vw, 2.5rem);
}

.content-page-card--document .page-content {
    max-width: 70ch;
    margin-inline: auto;
    font-size: 0.98rem;
    line-height: 1.85;
}

.content-page-card--document .page-content > * + * {
    margin-top: 1rem;
}

.search-results-shell {
    display: grid;
    gap: 1.35rem;
}

.search-results-frame {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(18rem, 0.8fr);
    gap: clamp(1.25rem, 4vw, 2.5rem);
    align-items: end;
    padding: clamp(1.4rem, 3vw, 2.2rem);
    border-radius: 1.75rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--color-primary-container) 28%, transparent) 0, transparent 48%),
        color-mix(in srgb, var(--color-surface-lowest) 94%, #ffffff 6%);
    box-shadow: var(--shadow-soft);
}

.search-results-intro {
    display: grid;
    gap: 0.85rem;
    max-width: 44rem;
}

.search-results-description,
.search-results-meta p {
    margin: 0;
    color: var(--color-on-surface-muted);
    line-height: 1.75;
}

.search-results-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.8rem;
    border-radius: 1.35rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 96%, #ffffff 4%);
}

.search-results-form input {
    min-height: 3.2rem;
    padding: 0 1rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: var(--color-surface-lowest);
    color: var(--color-on-surface);
    font: inherit;
}

.search-results-form .btn-primary {
    min-width: 9.5rem;
}

.search-results-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.search-results-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(19rem, 1fr));
    gap: 1.25rem;
    align-items: stretch;
}

.search-result-card {
    display: grid;
    gap: 0.85rem;
    align-content: start;
    min-height: 100%;
    padding: 1.5rem;
    border-radius: 1.35rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 84%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 92%, #ffffff 8%);
    box-shadow: var(--shadow-soft);
}

.search-result-card a {
    color: inherit;
}

.search-result-card .editorial-title {
    margin: 0;
    font-size: clamp(1.4rem, 2.2vw, 1.8rem);
    line-height: 1.12;
}

.search-result-card p {
    margin: 0;
    color: var(--color-on-surface-muted);
    line-height: 1.75;
}

.search-results-empty {
    display: grid;
    gap: 1rem;
    justify-items: start;
}

.error404 .content-page-card,
.error500 .content-page-card {
    max-width: 54rem;
    display: grid;
    gap: 1rem;
    padding: clamp(1.5rem, 3vw, 2.5rem);
}

.error404 .content-page-card p,
.error500 .content-page-card p {
    max-width: 42ch;
    color: var(--color-on-surface-muted);
}

.error404 .content-page-card .btn-outline,
.error500 .content-page-card .btn-outline {
    justify-self: flex-start;
}

.error404 .page-shell,
.error500 .page-shell {
    min-height: clamp(30rem, 68vh, 42rem);
    display: flex;
    align-items: center;
}

.error404 .container,
.error500 .container {
    width: 100%;
}

.error-state-shell {
    grid-template-columns: minmax(0, 1.15fr) minmax(16rem, 0.85fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
}

.error-state-copy,
.error-state-panel {
    display: grid;
    gap: 1rem;
}

.error-state-copy p {
    max-width: 44ch;
}

.error-state-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: center;
}

.error-state-panel {
    padding: clamp(1.1rem, 2vw, 1.5rem);
    border-radius: 1.35rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 95%, #ffffff 5%);
}

.error-state-panel h2 {
    margin: 0;
    font-size: 1.1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.error-state-links {
    display: grid;
    gap: 0.75rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.error-state-links a {
    color: var(--color-on-surface);
}

.woocommerce-cart .page-shell,
.woocommerce-account .page-shell {
    min-height: auto;
}

.woocommerce-cart .content-page-card--cart,
.woocommerce-account .content-page-card--account {
    max-width: 76rem;
    margin-inline: auto;
    padding: clamp(1.5rem, 3vw, 2.5rem);
}

.woocommerce-cart .page-content--cart,
.woocommerce-account .page-content--account {
    max-width: none;
}

.woocommerce-cart .wp-block-woocommerce-cart {
    margin: 0;
}

.woocommerce-cart .wp-block-woocommerce-empty-cart-block {
    display: grid;
    gap: 1.75rem;
    justify-items: center;
    padding: clamp(0.5rem, 2vw, 1rem) 0 0;
}

.woocommerce-cart .wp-block-woocommerce-empty-cart-block > .wp-block-heading {
    max-width: 16ch;
    margin: 0;
}

.woocommerce-cart .wc-block-cart__empty-cart__title.with-empty-cart-icon {
    position: relative;
    padding-top: 7.5rem;
}

.woocommerce-cart .wc-block-cart__empty-cart__title.with-empty-cart-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: 5.5rem;
    height: 5.5rem;
    border-radius: 50%;
    transform: translateX(-50%);
    background:
        radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.9), transparent 34%),
        linear-gradient(135deg, var(--color-primary-deep), color-mix(in srgb, var(--color-primary) 76%, var(--color-primary-deep)));
    box-shadow: 0 22px 46px rgba(54, 26, 43, 0.18);
}

.woocommerce-cart .wc-block-cart__empty-cart__title {
    margin-bottom: 0.25rem;
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.04;
}

.woocommerce-cart .wp-block-woocommerce-empty-cart-block .wc-block-components-product-name,
.woocommerce-cart .wp-block-woocommerce-empty-cart-block .wc-block-grid__product-title {
    text-wrap: balance;
}

.woocommerce-cart .wp-block-separator.is-style-dots {
    opacity: 0.22;
}

.woocommerce-cart .wp-block-product-new {
    display: grid;
    gap: 1.25rem;
    width: 100%;
}

.woocommerce-cart .wp-block-product-new > .wp-block-heading {
    margin: 0;
    text-align: center;
    font-size: clamp(1.4rem, 3vw, 2rem);
}

.woocommerce-cart .wc-block-grid .wc-block-grid__products,
.woocommerce-cart .wc-block-grid__products {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14.5rem, 1fr));
    gap: 1.25rem;
}

.woocommerce-cart .wc-block-grid .wc-block-grid__product,
.woocommerce-cart .wc-block-grid__product {
    display: grid;
    align-content: start;
    gap: 0.75rem;
    min-height: 100%;
    padding: 0.9rem;
    border-radius: 1.25rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 84%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 94%, #ffffff 6%);
    box-shadow: var(--shadow-soft);
    width: 100%;
    max-width: none;
    float: none;
    margin: 0;
}

.woocommerce-cart .wc-block-grid__product > * {
    width: 100%;
}

.woocommerce-cart .wc-block-grid__product-image img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 1rem;
}

.woocommerce-cart .wc-block-grid__product-title,
.woocommerce-cart .wc-block-components-product-name {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    line-height: 1.2;
}

.woocommerce-cart .wc-block-grid__product-price {
    color: var(--color-primary-deep);
    font-weight: 700;
}

.woocommerce-cart .wc-block-grid__product-add-to-cart {
    margin-top: auto;
}

.woocommerce-cart .wp-element-button,
.woocommerce-cart .wc-block-grid__product-add-to-cart .wp-block-button__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.9rem;
    width: 100%;
    padding: 0.8rem 1.2rem;
    border-radius: 999px;
    border: 1px solid transparent;
    background: linear-gradient(135deg, var(--color-primary-deep), var(--color-primary));
    color: var(--color-on-primary);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow: 0 18px 36px rgba(125, 49, 95, 0.18);
}

.woocommerce-account .page-header {
    margin-bottom: 1.5rem;
}

.woocommerce-account .page-content--account > .woocommerce {
    display: block;
}

.woocommerce-account .woocommerce-notices-wrapper {
    margin-bottom: 1rem;
}

.account-auth-shell {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(22rem, 1.15fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
}

.account-auth-shell--split {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}

.account-auth-intro,
.account-auth-panel,
.account-auth-panel-group {
    padding: clamp(1.25rem, 2.2vw, 1.6rem);
    border-radius: 1.5rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 94%, #ffffff 6%);
    box-shadow: var(--shadow-soft);
}

.account-auth-intro {
    display: grid;
    gap: 1rem;
}

.account-auth-eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 2.4rem;
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-primary-container) 74%, var(--color-surface-lowest));
    color: var(--color-primary-deep);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.account-auth-intro h2,
.account-auth-panel h2 {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    line-height: 1.06;
}

.account-auth-intro p,
.account-auth-intro li {
    color: var(--color-on-surface-muted);
    line-height: 1.72;
}

.account-auth-points {
    display: grid;
    gap: 0.75rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.account-auth-points li {
    padding-left: 1rem;
    position: relative;
}

.account-auth-points li::before {
    content: '';
    position: absolute;
    top: 0.72rem;
    left: 0;
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
}

.account-auth-panel-group {
    display: grid;
    gap: 1rem;
}

.account-auth-panel {
    display: grid;
    gap: 1rem;
    padding: 0;
    border: none;
    box-shadow: none;
    background: transparent;
}

.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
    display: grid;
    gap: 0.9rem;
}

.woocommerce-account .woocommerce-form-row label,
.woocommerce-account .form-row label {
    display: inline-flex;
    margin-bottom: 0.45rem;
    color: var(--color-on-surface);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.woocommerce-account .woocommerce-form .input-text {
    min-height: 3.25rem;
    padding: 0 1rem;
    border-radius: 1rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 88%, transparent);
    background: var(--color-surface-lowest);
    color: var(--color-on-surface);
    font: inherit;
}

.woocommerce-account .woocommerce-form .input-text:focus {
    outline: 2px solid rgba(176, 88, 134, 0.18);
    outline-offset: 2px;
    border-color: rgba(176, 88, 134, 0.32);
}

.woocommerce-account .form-row {
    margin: 0;
}

.woocommerce-account .form-row:last-child {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1rem;
}

.woocommerce-account .woocommerce-form-login__rememberme {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--color-on-surface-muted);
    font-size: 0.9rem;
}

.woocommerce-account .woocommerce-button.button,
.woocommerce-account .woocommerce-Button.button,
.single-product .product-summary-panel .single_add_to_cart_button,
.single-product .experience-summary-shell .single_add_to_cart_button,
.single-product .product-summary-panel .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.2rem;
    padding: 0.85rem 1.4rem;
    border-radius: 999px;
    border: 1px solid transparent;
    background: linear-gradient(135deg, var(--color-primary-deep), var(--color-primary));
    color: var(--color-on-primary);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    box-shadow: 0 18px 36px rgba(125, 49, 95, 0.18);
}

.woocommerce-account .lost_password {
    margin: 0;
}

.woocommerce-account .lost_password a {
    color: var(--color-primary-deep);
}

.single-product .site-main {
    padding-top: clamp(2.5rem, 5vw, 4.5rem);
}

.single-product .experience-product-shell {
    display: grid;
    gap: clamp(1.75rem, 4vw, 3rem);
}

.single-product .experience-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(18rem, 0.92fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
}

.single-product .experience-summary-shell,
.single-product .experience-media-shell,
.single-product .experience-detail-card {
    padding: clamp(1.25rem, 2.5vw, 2rem);
    border-radius: 1.75rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 95%, #ffffff 5%);
    box-shadow: var(--shadow-soft);
}

.single-product .experience-summary-shell {
    display: grid;
    align-content: start;
    gap: 1rem;
    align-self: start;
}

.single-product .product-kicker--experience {
    background: color-mix(in srgb, var(--color-primary-container) 68%, var(--color-surface-lowest));
}

.single-product .experience-title {
    margin: 0;
    font-size: clamp(2.4rem, 5vw, 4.25rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
    max-width: 11ch;
}

.single-product .experience-price {
    margin: 0;
}

.single-product .experience-summary-copy {
    color: var(--color-on-surface-muted);
    line-height: 1.85;
    max-width: 56ch;
}

.single-product .experience-summary-copy p {
    margin: 0;
}

.single-product .experience-summary-copy p + p {
    margin-top: 0.85rem;
}

.single-product .experience-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: center;
    padding-top: 0.5rem;
}

.single-product .experience-primary-action {
    min-width: 14rem;
}

.single-product .experience-meta-line {
    margin: 0;
    color: var(--color-on-surface-muted);
    font-size: 0.92rem;
}

.single-product .experience-media-shell {
    display: flex;
    align-items: stretch;
    min-height: clamp(24rem, 44vw, 41rem);
    overflow: hidden;
}

.single-product .experience-media-shell picture,
.single-product .experience-media-shell img {
    width: 100%;
    height: 100%;
}

.single-product .experience-media-shell img {
    object-fit: cover;
    border-radius: 1.2rem;
}

.single-product .experience-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(18rem, 0.88fr);
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: start;
}

.single-product .experience-detail-card {
    display: grid;
    align-content: start;
    gap: 1rem;
}

.single-product .experience-section-label {
    color: var(--color-primary-deep);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.single-product .experience-prose {
    color: var(--color-on-surface-muted);
    line-height: 1.85;
}

.single-product .experience-prose > * {
    max-width: 68ch;
}

.single-product .experience-prose > * + * {
    margin-top: 0.9rem;
}

.single-product .experience-detail-card--notes h2 {
    margin: 0;
    font-size: clamp(1.6rem, 3vw, 2.3rem);
    line-height: 1.08;
}

.single-product .experience-points {
    display: grid;
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.single-product .experience-points li {
    position: relative;
    padding-left: 1.1rem;
    color: var(--color-on-surface-muted);
    line-height: 1.75;
}

.single-product .experience-points li::before {
    content: '';
    position: absolute;
    top: 0.72rem;
    left: 0;
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
}

.single-product .experience-product-shell--academy .experience-media-shell {
    min-height: clamp(26rem, 48vw, 44rem);
}

.single-product .experience-product-shell--service .experience-title {
    font-size: clamp(2rem, 3.7vw, 3.2rem);
    max-width: 9ch;
}

.single-product .experience-product-shell--service .experience-summary-shell {
    gap: 0.85rem;
}

.single-product .experience-product-shell--service .experience-media-shell {
    min-height: clamp(21rem, 35vw, 31rem);
}

.single-product .woocommerce-content-wrap {
    width: min(1280px, calc(100% - 2rem));
    margin: 0 auto;
}

.single-product .product-spotlight-shell {
    display: grid;
    gap: clamp(2rem, 5vw, 4rem);
}

.single-product div.product.product-spotlight-shell {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: stretch;
}

.single-product div.product.product-spotlight-shell > * {
    float: none;
    width: 100%;
    margin: 0;
}

.single-product .product-spotlight {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(22rem, 0.82fr);
    gap: clamp(1.75rem, 4vw, 3.5rem);
    align-items: start;
}

.single-product .product-media-panel {
    display: grid;
    gap: 1rem;
}

.single-product .product-media-stage,
.single-product .product-summary-panel,
.single-product .product-secondary-flow .woocommerce-tabs,
.single-product .product-secondary-flow .related,
.single-product .product-secondary-flow .up-sells {
    padding: clamp(1rem, 2.2vw, 1.5rem);
    border-radius: 1.6rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 88%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 94%, #ffffff 6%);
    box-shadow: var(--shadow-soft);
}

.single-product .product-media-stage {
    min-height: clamp(24rem, 52vw, 42rem);
    display: flex;
    align-items: center;
    justify-content: center;
}

.single-product .product-media-stage img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 1.2rem;
}

.single-product .product-media-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(5rem, 1fr));
    gap: 0.75rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.single-product .product-media-thumbs img {
    width: 100%;
    border-radius: 1rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 80%, transparent);
}

.single-product .product-summary-panel {
    display: grid;
    gap: 0.95rem;
    position: sticky;
    top: 8.25rem;
}

.single-product .product-summary-panel .summary {
    display: grid;
    gap: 0.95rem;
    max-width: 24rem;
}

.single-product .product-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 2.2rem;
    padding: 0.4rem 0.8rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-primary-container) 74%, var(--color-surface-lowest));
    color: var(--color-primary-deep);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.15em;
    text-transform: uppercase;
}

.single-product .product_title {
    margin: 0;
    font-size: clamp(2.1rem, 4vw, 3.15rem);
    line-height: 1.02;
    letter-spacing: -0.03em;
}

.single-product p.price,
.single-product span.price {
    margin: 0;
    color: var(--color-primary-deep);
    font-size: clamp(1.45rem, 3vw, 2rem);
    font-weight: 700;
}

.single-product .woocommerce-product-details__short-description {
    max-width: 38ch;
    color: var(--color-on-surface-muted);
    line-height: 1.78;
}

.single-product form.cart {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 0.85rem;
    margin: 0.25rem 0 0;
}

.single-product form.cart .quantity {
    margin: 0;
}

.single-product form.cart .qty {
    min-width: 5.25rem;
    min-height: 3.2rem;
    padding: 0 0.9rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 84%, transparent);
    background: var(--color-surface-lowest);
    color: var(--color-on-surface);
    font: inherit;
}

.single-product .product_meta {
    display: grid;
    gap: 0.45rem;
    padding-top: 1rem;
    margin-top: 0.35rem;
    border-top: 1px solid color-mix(in srgb, var(--color-outline-variant) 82%, transparent);
    color: var(--color-on-surface-muted);
    font-size: 0.94rem;
}

.single-product .product_meta a {
    color: var(--color-primary-deep);
}

.single-product .woocommerce-tabs ul.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin: 0 0 1rem;
    padding: 0;
    list-style: none;
}

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

.single-product .woocommerce-tabs ul.tabs li a {
    display: inline-flex;
    align-items: center;
    min-height: 2.6rem;
    padding: 0.55rem 0.95rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 82%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 92%, #ffffff 8%);
    color: var(--color-on-surface);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.single-product .woocommerce-tabs .panel {
    color: var(--color-on-surface-muted);
    line-height: 1.8;
}

.single-product .related > h2,
.single-product .up-sells > h2 {
    margin-bottom: 1rem;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
}

.single-product .related ul.products,
.single-product .up-sells ul.products {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.single-product .related ul.products li.product,
.single-product .up-sells ul.products li.product {
    display: grid;
    align-content: start;
    gap: 0.7rem;
    min-height: 100%;
    padding: 0.9rem;
    border-radius: 1.2rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 84%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 96%, #ffffff 4%);
}

.single-product .related ul.products li.product img,
.single-product .up-sells ul.products li.product img {
    width: 100%;
    border-radius: 0.95rem;
}

.single-product .related ul.products li.product .woocommerce-loop-product__title,
.single-product .up-sells ul.products li.product .woocommerce-loop-product__title {
    font-size: 1.05rem;
}

.single-product .related ul.products li.product .price,
.single-product .up-sells ul.products li.product .price {
    font-size: 1rem;
}

.single-product .related ul.products li.product .button,
.single-product .up-sells ul.products li.product .button {
    min-height: 2.8rem;
    box-shadow: none;
}

.single-product .woocommerce-tabs,
.single-product .related,
.single-product .up-sells {
    margin-top: clamp(1.75rem, 4vw, 2.5rem);
}

.home .hero-content,
.blog .hero-content {
    background: rgba(255, 248, 251, 0.32);
    backdrop-filter: blur(8px);
}

.home .services-list .service-item {
    align-items: center;
    grid-template-columns: minmax(0, 1fr) auto;
}

@media (max-width: 980px) {
    .search-results-frame,
    .account-auth-shell,
    .account-auth-shell--split,
    .single-product .experience-hero,
    .single-product .experience-detail-grid,
    .single-product .product-spotlight,
    .error-state-shell {
        grid-template-columns: 1fr;
    }

    .single-product .product-summary-panel {
        position: static;
        top: auto;
    }
}

@media (max-width: 680px) {
    .single-product .experience-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .single-product .experience-primary-action,
    .single-product .experience-actions .btn-outline {
        width: 100%;
    }

    .search-results-form {
        grid-template-columns: 1fr;
    }

    .search-results-list,
    .single-product .related ul.products,
    .single-product .up-sells ul.products {
        grid-template-columns: 1fr;
    }

    .single-product .woocommerce-content-wrap {
        width: min(100% - 1.25rem, 1280px);
    }

    .single-product form.cart {
        align-items: stretch;
    }

    .single-product form.cart .quantity,
    .single-product form.cart .qty,
    .single-product form.cart .single_add_to_cart_button {
        width: 100%;
    }

    .woocommerce-cart .wc-block-grid .wc-block-grid__products,
    .woocommerce-cart .wc-block-grid__products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.9rem;
    }
}

.page-template-page-academy .academy-hero-sub .academy-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(18rem, 0.82fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
    text-align: left;
}

.page-template-page-academy .academy-hero-copy,
.page-template-page-academy .academy-hero-note,
.page-template-page-academy .academy-track-item {
    border-radius: 1.75rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-lowest) 95%, #ffffff 5%);
    box-shadow: var(--shadow-soft);
}

.page-template-page-academy .academy-hero-copy,
.page-template-page-academy .academy-hero-note {
    padding: clamp(1.35rem, 2.8vw, 2.25rem);
}

.page-template-page-academy .academy-hero-copy {
    display: grid;
    gap: 1rem;
}

.page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-title,
.page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-subtitle,
.page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-badges {
    margin-left: 0;
}

.page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-title {
    max-width: 12ch;
}

.page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-subtitle {
    max-width: 54ch;
}

.page-template-page-academy .academy-hero-note {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.page-template-page-academy .academy-note-label,
.page-template-page-academy .academy-track-eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 2rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-primary-container) 70%, var(--color-surface-lowest));
    color: var(--color-primary-deep);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.page-template-page-academy .academy-note-points {
    display: grid;
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-template-page-academy .academy-note-points li {
    position: relative;
    padding-left: 1rem;
    color: var(--color-on-surface-muted);
    line-height: 1.7;
}

.page-template-page-academy .academy-note-points li::before {
    content: '';
    position: absolute;
    top: 0.72rem;
    left: 0;
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 999px;
    background: var(--color-primary);
}

.page-template-page-academy .academy-list {
    display: grid;
    gap: clamp(1.5rem, 3vw, 2.25rem);
}

.page-template-page-academy .academy-track-item {
    grid-template-columns: minmax(0, 1.02fr) minmax(18rem, 0.98fr);
    grid-template-areas:
        'copy image'
        'footer image';
    align-items: start;
    gap: clamp(1.25rem, 3vw, 2.25rem);
    padding: clamp(1rem, 2.4vw, 1.5rem);
}

.page-template-page-academy .academy-track-item.reverse {
    grid-template-areas:
        'image copy'
        'image footer';
    grid-template-columns: minmax(18rem, 0.98fr) minmax(0, 1.02fr);
}

.page-template-page-academy .academy-track-copy {
    grid-area: copy;
}

.page-template-page-academy .academy-track-copy,
.page-template-page-academy .academy-track-footer,
.page-template-page-academy .academy-contact-panel .track-info {
    display: grid;
    gap: 0.85rem;
    align-content: start;
}

.page-template-page-academy .academy-track-copy h2 {
    margin: 0;
    max-width: 11ch;
}

.page-template-page-academy .academy-track-summary,
.page-template-page-academy .academy-track-format,
.page-template-page-academy .academy-contact-panel .track-info > p {
    margin: 0;
    max-width: 52ch;
    color: var(--color-on-surface-muted);
}

.page-template-page-academy .academy-track-format {
    font-size: 0.94rem;
}

.page-template-page-academy .academy-track-price {
    margin: 0;
}

.page-template-page-academy .academy-track-item .hero-actions {
    padding-top: 0.15rem;
}

.page-template-page-academy .academy-track-footer {
    grid-area: footer;
}

.page-template-page-academy .track-details-list {
    margin: 0;
}

.page-template-page-academy .track-image {
    grid-area: image;
    min-height: clamp(19rem, 34vw, 31rem);
    align-self: stretch;
}

.page-template-page-academy .track-image picture,
.page-template-page-academy .track-image img {
    width: 100%;
    height: 100%;
}

.page-template-page-academy .track-image img {
    object-fit: cover;
}

.page-template-page-academy .academy-contact-panel {
    grid-template-areas: 'info aside';
    grid-template-columns: minmax(0, 1.12fr) minmax(16rem, 0.88fr);
    align-items: center;
    gap: clamp(1.5rem, 3vw, 2.75rem);
}

.page-template-page-academy .academy-contact-panel .track-info {
    grid-area: info;
    gap: clamp(1rem, 2vw, 1.6rem);
    padding: clamp(1.35rem, 2.4vw, 2rem);
}

.page-template-page-academy .academy-contact-panel .track-info h2 {
    margin: 0;
    max-width: 14ch;
    font-size: clamp(2rem, 3.6vw, 3.35rem);
    line-height: 1.02;
    text-wrap: balance;
}

.page-template-page-academy .academy-contact-panel .track-info .hero-actions {
    padding-top: 0.5rem;
}

.page-template-page-academy .academy-contact-aside {
    grid-area: aside;
    display: grid;
    gap: 1rem;
    align-content: start;
    padding: clamp(1.15rem, 2.2vw, 1.65rem);
    border-radius: 1.45rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 72%, transparent);
    background: color-mix(in srgb, var(--color-primary-container) 30%, var(--color-surface-lowest) 70%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.page-template-page-academy .academy-contact-aside .academy-note-label {
    margin-bottom: 0.2rem;
}

.page-template-page-academy .academy-contact-aside .academy-note-points {
    gap: 1rem;
}

.page-template-page-academy .academy-contact-aside .academy-note-points li {
    padding-left: 1.15rem;
    font-size: 0.98rem;
    line-height: 1.75;
}

@media (max-width: 980px) {
    .page-template-page-academy .academy-hero-sub .academy-hero-layout,
    .page-template-page-academy .academy-track-item,
    .page-template-page-academy .academy-contact-panel {
        grid-template-columns: 1fr;
    }

    .page-template-page-academy .academy-contact-panel {
        grid-template-areas:
            'info'
            'aside';
        align-items: start;
    }

    .page-template-page-academy .academy-track-item,
    .page-template-page-academy .academy-track-item.reverse {
        grid-template-areas:
            'copy'
            'image'
            'footer';
    }

    .page-template-page-academy .academy-track-item.academy-contact-panel {
        grid-template-areas:
            'info'
            'aside';
        grid-template-columns: 1fr;
    }

    .page-template-page-academy .academy-hero-sub .academy-hero-layout .hero-title {
        max-width: 14ch;
    }

    .page-template-page-academy .academy-contact-aside {
        padding: 1.1rem;
    }

    .page-template-page-academy .academy-contact-panel .track-info h2 {
        max-width: none;
    }
}

@media (max-width: 680px) {
    .page-template-page-academy .academy-hero-copy,
    .page-template-page-academy .academy-hero-note,
    .page-template-page-academy .academy-track-item {
        border-radius: 1.35rem;
    }

    .page-template-page-academy .academy-track-copy h2 {
        max-width: none;
    }

    .page-template-page-academy .track-image {
        min-height: 16rem;
    }
}

/* ======================================================================
   WooCommerce "AI Slop" & UX Defaults Override
   ====================================================================== */

/* 1. Remove Side-Tabs and Edge Accents on widgets and lists */
.woocommerce ul.cart_list li dl::after, 
.woocommerce ul.cart_list li dl::before, 
.woocommerce ul.product_list_widget li dl::after, 
.woocommerce ul.product_list_widget li dl::before {
    display: none !important;
    content: none !important;
}
.woocommerce ul.cart_list li dl, 
.woocommerce ul.product_list_widget li dl {
    border-left: none !important;
    border-right: none !important;
}
.woocommerce-message, 
.woocommerce-error, 
.woocommerce-info {
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    box-shadow: var(--shadow-soft);
    border-radius: 1rem;
}

/* 2. Soften Pure Black (#000) to Deep Obsidian */
.woocommerce div.product div.images .flex-viewport,
.woocommerce-product-gallery__wrapper,
.woocommerce div.product div.images .woocommerce-product-gallery__image--placeholder {
    background: oklch(18% 0.01 250) !important;
}
p.demo_store, .woocommerce-store-notice {
    background: oklch(20% 0.05 340) !important; /* Tinted obsidian toward brand */
}

/* 3. Fix Bouncy Flexslider Animations & Layout Transitions */
.woocommerce div.product div.images .flex-viewport {
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.woocommerce div.product div.images .flexslider .slides > li {
    transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

/* 4. Increase Contrast on Secondary Text Links */
.error-state-links a, 
.search-results-meta p a {
    color: color-mix(in srgb, var(--color-primary-deep) 60%, #000) !important;
    font-weight: 600;
}

/* ======================================================================
   Final Polish: Interaction, Alignment, & Touch
   ====================================================================== */

/* 5. Interaction States for WooCommerce Buttons */
.woocommerce-account .woocommerce-button.button:hover,
.woocommerce-account .woocommerce-Button.button:hover,
.woocommerce-account .woocommerce-button.button:focus-visible,
.woocommerce-account .woocommerce-Button.button:focus-visible,
.single-product .product-summary-panel .single_add_to_cart_button:hover,
.single-product .product-summary-panel .single_add_to_cart_button:focus-visible,
.single-product .experience-summary-shell .single_add_to_cart_button:hover,
.single-product .experience-summary-shell .single_add_to_cart_button:focus-visible,
.single-product .product-summary-panel .button:hover,
.single-product .product-summary-panel .button:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 22px 44px rgba(125, 49, 95, 0.28);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.woocommerce-account .woocommerce-button.button:active,
.woocommerce-account .woocommerce-Button.button:active,
.single-product .product-summary-panel .single_add_to_cart_button:active,
.single-product .experience-summary-shell .single_add_to_cart_button:active,
.single-product .product-summary-panel .button:active {
    transform: translateY(0);
    box-shadow: var(--shadow-soft);
    transition: transform 0.1s ease, box-shadow 0.1s ease;
}

.woocommerce-account .woocommerce-button.button:disabled,
.woocommerce-account .woocommerce-Button.button:disabled,
.single-product .product-summary-panel .single_add_to_cart_button:disabled,
.single-product .experience-summary-shell .single_add_to_cart_button:disabled,
.single-product .product-summary-panel .button:disabled,
.single-product .product-summary-panel .single_add_to_cart_button.disabled,
.single-product .experience-summary-shell .single_add_to_cart_button.disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: none !important;
}

/* 6. Smooth Input Transitions (Forms) */
.woocommerce-account .woocommerce-form .input-text,
.woocommerce .quantity .qty {
    transition: border-color 0.3s ease, outline 0.3s ease, background 0.3s ease;
}

/* 7. Minimum 44px Touch Targets */
.woocommerce .quantity .qty {
    min-height: 44px;
    padding: 0 0.5rem;
    border-radius: 0.5rem;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 88%, transparent);
}
.woocommerce-tabs .wc-tabs li a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

/* 8. Notice Spacing and Margins */
.woocommerce-notices-wrapper {
    margin-bottom: var(--spacing-6);
}
