/* Ensure WC accessibility text is hidden even when theme misses it */
.bos-ma-root .screen-reader-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

.bos-ma-root {
    font-family: var(--bos-ma-font, inherit);
    font-weight: var(--bos-ma-font-weight-body, 400);
    background: var(--bos-ma-bg, #f8f9fa);
    color: var(--bos-ma-text, #111827);
    line-height: var(--bos-ma-line-height, 1.6);
    font-size: var(--bos-ma-font-size, 15px);
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    box-sizing: border-box;
}

.bos-ma-root *,
.bos-ma-root *::before,
.bos-ma-root *::after {
    box-sizing: border-box;
}

/* Remove focus ring on mouse click, keep it for keyboard navigation */
.bos-ma-root *:focus:not(:focus-visible) {
    outline: none !important;
    box-shadow: none !important;
}

.bos-ma-root *:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

.bos-ma-shell {
    display: block;
    max-width: 100%;
}

.bos-ma-layout--sidebar,
.bos-ma-main,
.bos-ma-content,
.bos-ma-tab-panel,
.bos-ma-dashboard,
.bos-ma-orders-list,
.bos-ma-account,
.bos-ma-addresses,
.bos-ma-wishlist {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.bos-ma-main {
    flex: 1;
    min-width: 0;
}

.bos-ma-content {
    padding: 20px 0;
    min-width: 0;
}

.bos-ma-tab-panel[data-animation="fade"] {
    animation: bos-ma-tab-fade var(--bos-ma-transition, 250ms) ease;
}

.bos-ma-tab-panel[data-animation="slide"] {
    animation: bos-ma-tab-slide var(--bos-ma-transition, 250ms) ease;
}

.bos-ma-nav {
    background: var(--bos-ma-nav-bg, #ffffff);
}

.bos-ma-nav--tabs-top {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--bos-ma-border, #e5e7eb);
    overflow-x: auto;
    padding-bottom: 2px;
}

.bos-ma-nav--sidebar {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
}

.bos-ma-nav--bottom-bar {
    position: fixed;
    inset-inline-start: 0;
    inset-inline-end: 0;
    bottom: 0;
    z-index: 9990;
    display: flex;
    justify-content: space-around;
    align-items: stretch;
    border-top: 1px solid var(--bos-ma-border, #e5e7eb);
    background: var(--bos-ma-bar-bg, #ffffff);
    box-shadow: var(--bos-ma-bar-shadow, 0 -1px 0 #f3f4f6);
    padding-bottom: env(safe-area-inset-bottom);
    height: calc(var(--bos-ma-bar-height, 64px) + env(safe-area-inset-bottom));
}

.bos-ma-nav-btn {
    min-height: max(44px, var(--bos-ma-input-height, 44px));
    border: 0;
    background: transparent;
    color: var(--bos-ma-nav-text, #6b7280);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: var(--bos-ma-nav-item-padding, 10px 16px);
    cursor: pointer;
    transition: color var(--bos-ma-transition, 250ms), background var(--bos-ma-transition, 250ms), border-color var(--bos-ma-transition, 250ms);
    white-space: nowrap;
    flex-shrink: 0;
    text-decoration: none;
    font-size: var(--bos-ma-nav-font-size, 14px);
    font-weight: var(--bos-ma-nav-font-weight, 600);
}

.bos-ma-nav-btn:hover {
    color: var(--bos-ma-nav-hover, var(--bos-ma-nav-text, #6b7280));
    background: var(--bos-ma-nav-hover-bg, transparent);
}

.bos-ma-nav-btn.is-active {
    color: var(--bos-ma-nav-active, var(--bos-ma-primary, #111111));
    background: var(--bos-ma-nav-active-bg, transparent);
}

.bos-ma-nav-btn.is-active:hover {
    color: var(--bos-ma-nav-active, var(--bos-ma-primary, #111111));
    background: var(--bos-ma-nav-active-bg, transparent);
}

.bos-ma-nav--tabs-top .bos-ma-nav-btn.is-active {
    border-bottom: 2px solid var(--bos-ma-nav-active, var(--bos-ma-primary, #111111));
    border-radius: 0;
}

.bos-ma-nav--sidebar .bos-ma-nav-btn {
    width: 100%;
    justify-content: flex-start;
    border-radius: var(--bos-ma-nav-radius, 8px);
}

.bos-ma-nav--sidebar .bos-ma-nav-btn.is-active {
    background: rgba(17, 24, 39, 0.04);
}

.bos-ma-nav--bottom-bar .bos-ma-nav-btn {
    flex: 1;
    flex-direction: column;
    gap: 4px;
    padding: 8px 6px;
    font-size: var(--bos-ma-bar-label-size, 11px);
    color: var(--bos-ma-bar-text, #9ca3af);
}

.bos-ma-nav--bottom-bar .bos-ma-nav-btn.is-active {
    color: var(--bos-ma-bar-active, var(--bos-ma-primary, #111111));
}

.bos-ma-nav-icon-wrap {
    width: var(--bos-ma-nav-icon-size, 20px);
    height: var(--bos-ma-nav-icon-size, 20px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.bos-ma-card {
    background: var(--bos-ma-card-bg, #ffffff);
    border: 1px solid var(--bos-ma-border, #e5e7eb);
    border-radius: var(--bos-ma-radius, 12px);
    box-shadow: var(--bos-ma-card-shadow, 0 1px 6px rgba(0,0,0,0.07));
    padding: var(--bos-ma-card-padding, 24px);
    transition: background var(--bos-ma-card-hover-transition, 250ms), border-color var(--bos-ma-transition, 250ms);
}

.bos-ma-card,
.bos-ma-order-card,
.bos-ma-product-card,
.bos-ma-wishlist-item {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.bos-ma-card--flat {
    box-shadow: none;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.bos-ma-card--danger {
    border-color: rgba(239, 68, 68, 0.18);
}

.bos-ma-card-head,
.bos-ma-order-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.bos-ma-dashboard-logout {
    margin-inline-end: auto;
    flex-shrink: 0;
    background: transparent;
    color: var(--bos-ma-danger, #dc2626);
    border: 1px solid var(--bos-ma-danger-border, rgba(239, 68, 68, 0.28));
}

.bos-ma-dashboard-logout:hover {
    background: var(--bos-ma-danger-bg, rgba(239, 68, 68, 0.05));
    color: var(--bos-ma-danger, #dc2626);
}

.bos-ma-title {
    margin: 0;
    font-size: var(--bos-ma-font-size-heading, 18px);
    font-weight: var(--bos-ma-font-weight-heading, 600);
    color: var(--bos-ma-text, #111827);
}

.bos-ma-subtitle {
    margin: 0 0 10px;
    font-size: var(--bos-ma-font-size-subheading, 15px);
    font-weight: 600;
}

.bos-ma-muted-text,
.bos-ma-order-meta,
.bos-ma-strength-label {
    color: var(--bos-ma-muted, #6b7280);
    font-size: var(--bos-ma-font-size-sm, 13px);
}

.bos-ma-grid {
    display: grid;
    row-gap: max(var(--bos-ma-block-gap-row, 20px), 20px);
    column-gap: max(var(--bos-ma-block-gap-column, 20px), 20px);
}

.bos-ma-grid--dashboard,
.bos-ma-account-grid,
.bos-ma-address-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bos-ma-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: max(var(--bos-ma-block-gap-row, 20px), 20px);
    column-gap: max(var(--bos-ma-block-gap-column, 20px), 20px);
}

.bos-ma-stat {
    border: 1px solid var(--bos-ma-divider, #f3f4f6);
    border-radius: calc(var(--bos-ma-radius, 12px) - 4px);
    padding: 18px;
}

.bos-ma-stat strong {
    display: block;
    margin-top: 6px;
    font-size: var(--bos-ma-stat-value-size, 18px);
    color: var(--bos-ma-text, #111827);
}

.bos-ma-stat-label {
    display: block;
    color: var(--bos-ma-muted, #6b7280);
    font-size: var(--bos-ma-font-size-sm, 13px);
}

.bos-ma-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--bos-ma-badge-padding, 3px 10px);
    border-radius: var(--bos-ma-badge-radius, 20px);
    font-size: var(--bos-ma-badge-font-size, 12px);
    font-weight: 600;
    border: 0;
    box-shadow: none;
    white-space: nowrap;
}

.bos-ma-order-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.bos-ma-order-number {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 4px;
}

.bos-ma-order-head-side {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.bos-ma-order-items-strip,
.bos-ma-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.bos-ma-actions {
    margin-top: 24px;
}

.bos-ma-actions--center {
    justify-content: center;
}

.bos-ma-thumb,
.bos-ma-order-item-image,
.bos-ma-product-image-wrap,
.bos-ma-wishlist-image {
    width: var(--bos-ma-order-img-size, 40px);
    height: var(--bos-ma-order-img-size, 40px);
    border-radius: var(--bos-ma-order-img-radius, 6px);
    overflow: hidden;
    background: #f3f4f6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.bos-ma-thumb img,
.bos-ma-order-item-image img,
.bos-ma-product-image,
.bos-ma-wishlist-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.bos-ma-thumb--count {
    color: var(--bos-ma-muted, #6b7280);
    font-size: 12px;
    font-weight: 700;
}

.bos-ma-btn {
    min-height: max(44px, var(--bos-ma-input-height, 44px));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: var(--bos-ma-btn-padding, 10px 20px);
    border-radius: var(--bos-ma-btn-radius, 8px);
    border: 0;
    background: var(--bos-ma-btn-bg, var(--bos-ma-primary, #111111));
    color: var(--bos-ma-btn-text, #ffffff);
    cursor: pointer;
    text-decoration: none;
    font-weight: var(--bos-ma-btn-weight, 700);
    font-size: var(--bos-ma-btn-font-size, 14px);
    transition: opacity var(--bos-ma-transition, 250ms), background var(--bos-ma-transition, 250ms), color var(--bos-ma-transition, 250ms), border-color var(--bos-ma-transition, 250ms);
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
}

.bos-ma-btn:hover,
.bos-ma-btn:focus,
.bos-ma-btn:active {
    opacity: var(--bos-ma-btn-hover-opacity, 0.88) !important;
    background: var(--bos-ma-btn-hover-bg, var(--bos-ma-btn-bg, var(--bos-ma-primary, #111111))) !important;
    color: var(--bos-ma-btn-hover-text, var(--bos-ma-btn-text, #ffffff)) !important;
    box-shadow: none !important;
    outline: none !important;
}

.bos-ma-btn:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.bos-ma-btn--secondary {
    background: var(--bos-ma-btn-sec-bg, #f3f4f6);
    color: var(--bos-ma-btn-sec-text, #374151);
    border: var(--bos-ma-btn-sec-border, 1px solid #e5e7eb);
    font-weight: var(--bos-ma-btn-sec-weight, 600);
    padding: var(--bos-ma-btn-sec-padding, 8px 16px);
    font-size: var(--bos-ma-btn-font-size, 14px);
    border-radius: var(--bos-ma-btn-sec-radius, var(--bos-ma-btn-radius, 8px));
    box-shadow: none;
    opacity: 1;
}

.bos-ma-btn--secondary:hover,
.bos-ma-btn--secondary:focus,
.bos-ma-btn--secondary:active {
    background: var(--bos-ma-btn-sec-hover-bg, #e9eaec) !important;
    color: var(--bos-ma-btn-sec-hover-text, var(--bos-ma-btn-sec-text, #374151)) !important;
    opacity: 1 !important;
}

.bos-ma-btn--danger {
    background: transparent;
    color: var(--bos-ma-danger, #ef4444);
    border: 1px solid var(--bos-ma-danger-border, #fca5a5);
    opacity: 1;
}

.bos-ma-btn--danger:hover,
.bos-ma-btn--danger:focus,
.bos-ma-btn--danger:active {
    background: var(--bos-ma-danger-bg, rgba(239,68,68,0.05)) !important;
    color: var(--bos-ma-danger, #ef4444) !important;
    opacity: 1 !important;
}

.bos-ma-btn--small {
    min-height: 34px;
    padding: var(--bos-ma-btn-small-padding, 6px 14px);
    font-size: var(--bos-ma-btn-small-font-size, 13px);
    font-weight: 600;
    border-radius: var(--bos-ma-btn-radius, 8px);
}

.bos-ma-dialog-overlay {
    position: fixed;
    inset: 0;
    z-index: 100060;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(17, 24, 39, 0.42);
}

.bos-ma-dialog {
    width: min(420px, calc(100vw - 32px));
    background: var(--bos-ma-popup-bg, #ffffff);
    border: 1px solid var(--bos-ma-border, #e5e7eb);
    border-radius: var(--bos-ma-popup-radius, 16px);
    padding: var(--bos-ma-card-padding, 24px);
    box-shadow: var(--bos-ma-popup-shadow, 0 20px 60px rgba(0, 0, 0, 0.18));
}

.bos-ma-dialog-title {
    margin: 0 0 8px;
    font-size: var(--bos-ma-popup-title-size, 20px);
    font-weight: var(--bos-ma-popup-title-weight, 700);
    color: var(--bos-ma-text, #111827);
}

.bos-ma-dialog-text {
    margin: 0;
    color: var(--bos-ma-muted, #6b7280);
    line-height: 1.7;
}

.bos-ma-field {
    display: block;
    margin-bottom: 20px;
}

.bos-ma-label {
    display: block;
    color: var(--bos-ma-label-color, #374151);
    font-size: var(--bos-ma-label-font-size, 13px);
    font-weight: var(--bos-ma-label-font-weight, 500);
    margin-bottom: 6px;
}

.bos-ma-form-grid,
.bos-ma-order-details-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 0;
    column-gap: 20px;
}

.bos-ma-order-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    border-top: 0;
    border-bottom: 1px solid var(--bos-ma-divider, #f9fafb);
}

.bos-ma-order-item:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.bos-ma-order-item-main {
    flex: 1;
    min-width: 0;
}

.bos-ma-order-item-name,
.bos-ma-product-title {
    color: var(--bos-ma-text, #111827);
    text-decoration: none;
    font-weight: 600;
}

.bos-ma-product-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.bos-ma-order-item-meta,
.bos-ma-product-price {
    color: var(--bos-ma-muted, #6b7280);
    font-size: var(--bos-ma-font-size-sm, 13px);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.bos-ma-product-price del {
    color: var(--bos-ma-muted, #9ca3af);
    font-size: 0.9em;
    font-weight: 400;
    text-decoration: line-through;
    opacity: 0.7;
}
.bos-ma-product-price ins {
    color: var(--bos-ma-text, #111827);
    font-weight: 700;
    text-decoration: none;
    font-size: 1.05em;
}

.bos-ma-order-item-total {
    color: var(--bos-ma-text, #111827);
    font-weight: 600;
    white-space: nowrap;
}

.bos-ma-kv {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.bos-ma-kv-row,
.bos-ma-total-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.bos-ma-kv-label {
    color: var(--bos-ma-muted, #6b7280);
}

.bos-ma-total-row.is-total {
    font-size: 16px;
    font-weight: 700;
}

.bos-ma-address-summary,
.bos-ma-address-text {
    color: var(--bos-ma-text, #111827);
}

.bos-ma-recommended-strip {
    display: flex;
    gap: 20px;
    align-items: stretch;
    overflow-x: auto;
    padding-bottom: 6px;
}

.bos-ma-product-card,
.bos-ma-wishlist-item {
    min-width: 220px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.bos-ma-product-card {
    min-width: 230px;
    flex-direction: column;
    justify-content: flex-start;
    height: auto;
}

.bos-ma-product-image-wrap {
    width: 100%;
    height: 160px;
}

.bos-ma-product-content,
.bos-ma-wishlist-main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.bos-ma-product-card .bos-ma-product-title {
    flex: 1 1 auto;
}

.bos-ma-product-card .bos-ma-btn {
    align-self: stretch;
    margin-top: 4px;
}

.bos-ma-wishlist {
    display: grid;
    row-gap: 20px;
    column-gap: 20px;
}

.bos-ma-empty,
.bos-ma-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 32px 16px;
    text-align: center;
    color: var(--bos-ma-muted, #6b7280);
}

.bos-ma-order-details-loading {
    padding-top: 20px;
    color: var(--bos-ma-muted, #6b7280);
}

.bos-ma-spinner {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid rgba(17, 24, 39, 0.12);
    border-top-color: var(--bos-ma-primary, #111111);
    animation: bos-ma-spin 0.8s linear infinite;
}

.bos-ma-toast {
    position: fixed;
    inset-inline-end: 16px;
    bottom: calc(var(--bos-ma-bar-height, 64px) + env(safe-area-inset-bottom) + 16px);
    z-index: 9995;
    padding: 10px 14px;
    border-radius: 10px;
    background: var(--bos-ma-toast-bg, #111827);
    color: var(--bos-ma-toast-text, #ffffff);
    font-size: 13px;
    box-shadow: 0 10px 30px rgba(17, 24, 39, 0.18);
}

.bos-ma-toast.is-error {
    background: var(--bos-ma-toast-error-bg, #b91c1c);
}

.bos-ma-strength-wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 8px 0 14px;
}

.bos-ma-strength {
    display: flex;
    gap: 6px;
}

.bos-ma-strength-bar {
    flex: 1;
    height: 4px;
    border-radius: 999px;
    background: var(--bos-ma-divider, #f3f4f6);
}

.bos-ma-strength-bar.is-active.s1 { background: #ef4444; }
.bos-ma-strength-bar.is-active.s2 { background: #f97316; }
.bos-ma-strength-bar.is-active.s3 { background: #eab308; }
.bos-ma-strength-bar.is-active.s4 { background: #22c55e; }

/* Timeline, desktop horizontal */
.bos-ma-timeline {
    display: flex;
    align-items: flex-start;
    gap: 0;
    padding: 20px 0 8px;
    position: relative;
    max-width: 420px;
    margin: 0 auto;
}

/* First block has no connector */
.bos-ma-timeline-block {
    display: flex;
    align-items: flex-start;
    flex: 0 0 auto;
    min-width: 0;
}

/* Connector stretches between dots */
.bos-ma-timeline-connector {
    flex: 0 1 auto;
    width: 120px;
    height: 3px;
    margin-top: calc(var(--bos-ma-timeline-dot, 20px) / 2);
    background: var(--bos-ma-timeline-line, #e5e7eb);
    border-radius: 3px;
    transition: background 0.4s ease;
}

.bos-ma-timeline-connector.is-done {
    background: var(--bos-ma-primary, #111111);
}

.bos-ma-timeline-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    text-align: center;
    position: relative;
    min-width: 56px;
}

.bos-ma-timeline-dot {
    width: var(--bos-ma-timeline-dot, 20px);
    height: var(--bos-ma-timeline-dot, 20px);
    border-radius: 50%;
    border: 3px solid var(--bos-ma-border, #e5e7eb);
    background: var(--bos-ma-card-bg, #ffffff);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.3s ease;
    position: relative;
    z-index: 1;
}

.bos-ma-timeline-dot.is-done {
    background: var(--bos-ma-primary, #111111);
    border-color: var(--bos-ma-primary, #111111);
}

.bos-ma-timeline-dot.is-active {
    background: var(--bos-ma-primary, #111111);
    border-color: var(--bos-ma-primary, #111111);
    box-shadow: 0 0 0 4px rgba(17,17,17,0.12);
    animation: bos-ma-pulse 2s ease infinite;
}

.bos-ma-timeline-dot.is-error {
    background: var(--bos-ma-danger, #dc2626);
    border-color: var(--bos-ma-danger, #dc2626);
    box-shadow: 0 0 0 4px rgba(220,38,38,0.12);
}

.bos-ma-timeline-text {
    font-size: var(--bos-ma-timeline-label-size, 13px);
    color: var(--bos-ma-muted, #6b7280);
    font-weight: 500;
    line-height: 1.3;
    white-space: nowrap;
}

.bos-ma-timeline-step:has(.is-done) .bos-ma-timeline-text,
.bos-ma-timeline-step:has(.is-active) .bos-ma-timeline-text {
    color: var(--bos-ma-text, #111827);
    font-weight: 600;
}

.bos-ma-guest-prompt {
    padding: 24px 0;
}

.bos-ma-guest-prompt .bos-ma-card {
    max-width: 420px;
    margin: 0 auto;
    text-align: center;
}

.bos-ma-dashboard > * + * {
    margin-top: 28px;
}

.bos-ma-dashboard-recommended {
    margin-top: 28px;
}

.bos-ma-orders-list > .bos-ma-order-card + .bos-ma-order-card {
    margin-top: 12px;
}

.bos-ma-orders-list > .bos-ma-actions--center {
    margin-top: 28px;
}

.bos-ma-account,
.bos-ma-addresses {
    display: grid;
    gap: 20px;
}

.bos-ma-account-section + .bos-ma-account-section {
    margin-top: 28px;
}

.bos-ma-account-section--danger {
    border-top: 1px solid var(--bos-ma-danger-border, #fee2e2);
    padding-top: 24px;
}

.bos-ma-actions--account {
    margin-top: 24px;
    gap: 10px;
}

.bos-ma-actions--danger-zone {
    margin-top: 20px;
}

.bos-ma-address-summary {
    color: var(--bos-ma-text, #111827);
    white-space: pre-line;
    margin-top: 0;
}

.bos-ma-address-summary.is-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    text-align: center;
    color: var(--bos-ma-muted, #9ca3af);
    font-size: var(--bos-ma-font-size-sm, 14px);
}

.bos-ma-actions--address {
    margin-top: 20px;
    gap: 8px;
    grid-column: 1 / -1;
}

.bos-ma-order-card {
    padding: var(--bos-ma-order-padding, var(--bos-ma-card-padding, 24px));
}

.bos-ma-order-head {
    margin-bottom: 16px;
}

.bos-ma-order-details {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--bos-ma-divider, #f3f4f6);
}

.bos-ma-order-section--timeline {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
}

.bos-ma-order-section + .bos-ma-order-section {
    border-top: 1px solid var(--bos-ma-divider, #f3f4f6);
    padding-top: 20px;
    margin-top: 20px;
}

.bos-ma-order-details-meta {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.bos-ma-order-details-kv {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    flex: 1;
    min-width: min(100%, 420px);
}

.bos-ma-order-details-kv-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.bos-ma-order-details-kv-label {
    color: var(--bos-ma-muted, #6b7280);
    font-size: var(--bos-ma-font-size-sm, 13px);
}

.bos-ma-order-details-kv-value {
    color: var(--bos-ma-text, #111827);
    font-size: var(--bos-ma-font-size, 14px);
    font-weight: 600;
}

.bos-ma-order-note {
    margin-top: 16px;
    color: var(--bos-ma-muted, #4b5563);
    font-size: var(--bos-ma-font-size-sm, 14px);
}

.bos-ma-order-items-list {
    margin-top: 0;
}

.bos-ma-card > .bos-ma-order-meta + .bos-ma-order-items-strip,
.bos-ma-card > .bos-ma-stats + .bos-ma-actions,
.bos-ma-card > .bos-ma-order-items-strip + .bos-ma-actions {
    margin-top: 20px;
}

.bos-ma-order-addresses {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.bos-ma-order-address-block .bos-ma-subtitle,
.bos-ma-order-section .bos-ma-subtitle {
    margin: 0 0 12px;
}

.bos-ma-address-text {
    color: var(--bos-ma-text, #111827);
    line-height: 1.8;
}

.bos-ma-address-text p {
    margin: 0;
}

.bos-ma-address-text br + br {
    display: none;
}

.bos-ma-totals {
    width: min(100%, 360px);
    margin-inline-end: 0;
    margin-inline-start: auto;
}

.bos-ma-total-row {
    padding: 6px 0;
}

.bos-ma-total-row span {
    color: var(--bos-ma-muted, #6b7280);
}

.bos-ma-total-row strong {
    color: var(--bos-ma-text, #111827);
    font-weight: 600;
}

.bos-ma-total-row.is-total {
    border-top: 1px solid var(--bos-ma-border, #e5e7eb);
    padding-top: 12px;
    margin-top: 8px;
    font-size: 16px;
    font-weight: 700;
}

.bos-ma-total-row.is-total strong,
.bos-ma-total-row.is-total span {
    font-weight: 700;
    color: var(--bos-ma-text, #111827);
}

.bos-ma-actions--details {
    margin-top: 0;
    gap: 8px;
}

.bos-ma-support-box {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--bos-ma-divider, #f3f4f6);
}

.bos-ma-actions--support {
    margin-top: 20px;
}

.bos-ma-product-card {
    padding: var(--bos-ma-order-padding, var(--bos-ma-card-padding, 24px));
    border: 1px solid var(--bos-ma-border, #e5e7eb);
    border-radius: var(--bos-ma-radius, 12px);
    background: var(--bos-ma-card-bg, #ffffff);
}

.bos-ma-wishlist-item {
    align-items: stretch;
}

.bos-ma-wishlist-main .bos-ma-actions {
    margin-top: 12px;
}

.bos-ma-root input[type="text"],
.bos-ma-root input[type="email"],
.bos-ma-root input[type="password"],
.bos-ma-root input[type="number"],
.bos-ma-root input[type="tel"],
.bos-ma-root select,
.bos-ma-root textarea {
    display: block;
    width: 100%;
    box-sizing: border-box;
    height: var(--bos-ma-input-height, 44px);
    padding: var(--bos-ma-input-padding, 0 14px);
    font-size: var(--bos-ma-input-font-size, 15px);
    font-family: inherit;
    color: var(--bos-ma-input-text, #111827);
    background: var(--bos-ma-input-bg, #ffffff);
    border: 1px solid var(--bos-ma-input-border, #d1d5db);
    border-radius: var(--bos-ma-input-radius, 8px);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    appearance: none;
    -webkit-appearance: none;
}

.bos-ma-root textarea {
    height: auto;
    min-height: 100px;
    padding: 12px 14px;
    resize: vertical;
}

.bos-ma-root input:focus-visible,
.bos-ma-root select:focus-visible,
.bos-ma-root textarea:focus-visible {
    outline: none;
    border-color: var(--bos-ma-input-focus, var(--bos-ma-primary, #111111));
    box-shadow: none;
}

.bos-ma-root button:focus:not(:focus-visible),
.bos-ma-root a:focus:not(:focus-visible),
.bos-ma-root input:focus:not(:focus-visible),
.bos-ma-root select:focus:not(:focus-visible) {
    outline: none !important;
    box-shadow: none !important;
}

.bos-ma-root input::placeholder,
.bos-ma-root textarea::placeholder {
    color: var(--bos-ma-placeholder, #9ca3af);
}

@keyframes bos-ma-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(17, 24, 39, 0.2); }
    50% { box-shadow: 0 0 0 8px rgba(17, 24, 39, 0); }
}

@keyframes bos-ma-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes bos-ma-tab-fade {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes bos-ma-tab-slide {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 767px) {
    .bos-ma-root input,
    .bos-ma-root select,
    .bos-ma-root textarea {
        font-size: max(16px, var(--bos-ma-input-font-size, 15px));
    }

    .bos-ma-root.nav-bottom-bar .bos-ma-content {
        padding-bottom: calc(var(--bos-ma-bar-height, 64px) + env(safe-area-inset-bottom) + 16px);
    }

    .bos-ma-shell,
    .bos-ma-main,
    .bos-ma-content,
    .bos-ma-tab-panel,
    .bos-ma-dashboard,
    .bos-ma-orders-list,
    .bos-ma-account,
    .bos-ma-addresses,
    .bos-ma-wishlist,
    .bos-ma-card,
    .bos-ma-order-card,
    .bos-ma-product-card,
    .bos-ma-wishlist-item {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .bos-ma-layout--sidebar {
        flex-direction: column;
        gap: 16px;
    }

    .bos-ma-nav--sidebar {
        position: static;
        min-width: 0;
        flex-direction: row;
        overflow-x: auto;
        width: 100%;
        border-bottom: 1px solid var(--bos-ma-border, #e5e7eb);
    }

    .bos-ma-nav--sidebar .bos-ma-nav-btn {
        width: auto;
        justify-content: center;
        border-radius: 0;
        border-bottom: 2px solid transparent;
        padding: 10px 14px;
    }

    .bos-ma-nav--sidebar .bos-ma-nav-btn.is-active {
        background: transparent;
        border-bottom-color: var(--bos-ma-nav-active, var(--bos-ma-primary, #111111));
    }

    .bos-ma-grid--dashboard,
    .bos-ma-account-grid,
    .bos-ma-address-grid,
    .bos-ma-form-grid,
    .bos-ma-order-details-grid {
        grid-template-columns: 1fr;
    }

    .bos-ma-card,
    .bos-ma-order-card,
    .bos-ma-account > .bos-ma-card,
    .bos-ma-addresses > .bos-ma-card {
        padding: 16px;
    }

    .bos-ma-stats {
        column-gap: 12px;
        row-gap: 12px;
    }

    .bos-ma-stat {
        padding: 14px;
    }

    .bos-ma-stat strong {
        font-size: 16px;
    }

    .bos-ma-order-details-kv,
    .bos-ma-order-addresses {
        grid-template-columns: 1fr;
    }

    .bos-ma-order-section--timeline {
        overflow: visible;
    }

    .bos-ma-order-section--timeline .bos-ma-subtitle {
        margin-bottom: 14px;
    }

    .bos-ma-timeline {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 8px 0 4px;
        max-width: none;
    }

    .bos-ma-timeline-block {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        min-width: 0;
        flex: none;
        width: 100%;
    }

    .bos-ma-timeline-step {
        flex-direction: row;
        min-width: 0;
        width: auto;
        gap: 12px;
        text-align: start;
    }

    .bos-ma-timeline-connector {
        width: 3px;
        height: 24px;
        margin: 0;
        margin-inline-start: calc(var(--bos-ma-timeline-dot, 20px) / 2 - 1px);
        margin-top: 0;
    }

    .bos-ma-timeline-text {
        font-size: 14px;
        font-weight: 500;
        line-height: var(--bos-ma-timeline-dot, 20px);
        white-space: normal;
    }

    .bos-ma-order-head,
    .bos-ma-order-details-meta {
        flex-direction: column;
        align-items: stretch;
    }

    .bos-ma-grid--dashboard > .bos-ma-card:first-child .bos-ma-card-head {
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
    }

    .bos-ma-grid--dashboard > .bos-ma-card:first-child .bos-ma-card-head > div {
        min-width: 0;
        flex: 1;
    }

    .bos-ma-grid--dashboard > .bos-ma-card:first-child .bos-ma-title,
    .bos-ma-grid--dashboard > .bos-ma-card:first-child .bos-ma-muted-text {
        text-align: start;
    }

    .bos-ma-grid--dashboard > .bos-ma-card:first-child .bos-ma-dashboard-logout {
        margin-inline-end: 0;
        align-self: flex-start;
    }

    .bos-ma-order-head-side {
        justify-content: space-between;
    }

    .bos-ma-actions--details {
        flex-direction: column;
        align-items: stretch;
    }

    .bos-ma-actions--details .bos-ma-btn {
        width: 100%;
        justify-content: center;
    }

    .bos-ma-order-item {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .bos-ma-order-item-total {
        width: 100%;
        padding-inline-end: calc(var(--bos-ma-order-img-size, 40px) + 12px);
        text-align: end;
    }

    .bos-ma-product-card,
    .bos-ma-wishlist-item {
        min-width: 0;
    }

    .bos-ma-recommended-strip {
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .bos-ma-recommended-strip::-webkit-scrollbar {
        display: none;
    }

    .bos-ma-product-card {
        min-width: calc(100% - 32px);
        scroll-snap-align: start;
    }

    .bos-ma-wishlist-item {
        flex-direction: column;
        align-items: stretch;
    }

    .bos-ma-wishlist-image {
        width: 100%;
        height: 180px;
    }

    .bos-ma-wishlist-main .bos-ma-actions {
        width: 100%;
    }

    .bos-ma-wishlist-main .bos-ma-actions .bos-ma-btn {
        flex: 1 1 auto;
    }

    .bos-ma-totals {
        width: 100%;
    }

    .bos-ma-dialog-overlay {
        padding: 16px;
    }

    .bos-ma-dialog {
        width: 100%;
        padding: 20px;
    }
}

@media (min-width: 768px) {
    .bos-ma-layout--sidebar {
        display: flex;
        flex-direction: row;
        gap: 24px;
        align-items: flex-start;
    }

    .bos-ma-nav--sidebar {
        display: flex;
        flex-direction: column;
        min-width: 180px;
        width: 180px;
        flex-shrink: 0;
        position: sticky;
        top: 20px;
    }

    .bos-ma-content {
        flex: 1;
        min-width: 0;
    }
}
