/* Storefront-only visual styles (product grid, cart panel, and store hero). */

.store-hero {
    background: linear-gradient(160deg, #1a1a1a 0%, #2a2a2a 60%, #3a3a3a 100%);
    color: #fff;
    padding: 3rem 0;
}

.store-layout {
    padding: 3rem 0;
    background: #f7f7f7;
}

.navbar {
    position: sticky;
    top: 0;
    z-index: 2101;
}

.category-pills .btn {
    margin: 0 0.5rem 0.5rem 0;
}

.product-card {
    border: 1px solid #e5e5e5;
    border-radius: 0.75rem;
    background: #fff;
    height: 100%;
}

.product-card img {
    border-top-left-radius: 0.75rem;
    border-top-right-radius: 0.75rem;
    object-fit: cover;
    height: 170px;
}

.product-detail-media .product-card {
    overflow: hidden;
    height: auto;
}

.product-detail-media .product-detail-main-image {
    display: block;
    width: 100%;
    height: auto;
    max-height: 60vh;
    object-fit: contain;
    background: #fff;
}

.product-detail-thumb {
    display: block;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.product-detail-thumb-button {
    display: block;
    width: 100%;
    border: 1px solid #d7d7d7;
    border-radius: 0.35rem;
    padding: 0;
    background: #fff;
    overflow: hidden;
}

.product-detail-thumb-button .product-detail-thumb {
    border: 0 !important;
    border-radius: 0 !important;
}

.product-detail-thumb-button.is-active {
    border-color: #111;
    box-shadow: 0 0 0 1px #111 inset;
}

.product-option-listbox {
    min-height: 13rem;
}

.image-gallery-grid {
    max-height: min(46vh, 420px);
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.25rem;
}

.image-gallery-grid .row {
    margin-left: 0;
    margin-right: 0;
    align-content: flex-start;
}

.image-gallery-grid--paged {
    max-height: none;
    overflow: visible;
    padding-right: 0;
}

.image-gallery-grid__controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.product-gallery-nav {
    min-width: 2.2rem;
    line-height: 1;
    font-weight: 700;
}

.image-gallery-grid--paged .product-detail-thumb-row {
    margin-left: 0;
    margin-right: 0;
}

.image-gallery-grid--admin {
    max-height: min(42vh, 360px);
}

.cart-panel {
    position: sticky;
    top: 5rem;
}

.cart-item + .cart-item {
    border-top: 1px solid #ededed;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
}

.cart-item-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.cart-qty-form {
    align-items: center;
}

.cart-qty-input {
    max-width: 90px;
}

.cart-request-indicator {
    display: none;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    color: #6c757d;
    font-size: 0.9rem;
}

.cart-request-indicator.htmx-request {
    display: inline-flex;
}

.btn:disabled,
button:disabled {
    cursor: not-allowed;
}

.price {
    font-weight: 700;
}

.summary-box {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 0.75rem;
    padding: 1rem;
}

.vehicle-selector-panel {
    border-color: #cfd6dd;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 249, 251, 0.98) 100%);
}

/* Store admin dashboard styling. Scoped to avoid storefront side effects. */
.store-admin-page {
    background:
        radial-gradient(circle at 18% -10%, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0) 38%),
        linear-gradient(180deg, #eef2f6 0%, #f4f6f8 100%);
}

.store-admin-page .admin-topbar {
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08);
}

.store-admin-page .admin-shell {
    padding-top: 1rem;
    padding-bottom: 1.25rem;
}

.store-admin-page .admin-shell__inner {
    max-width: 1240px;
    margin: 0 auto;
}

.store-admin-page .admin-card {
    border: 1px solid #d8dee5;
    border-radius: 0.75rem;
    box-shadow: 0 8px 18px rgba(20, 33, 47, 0.04);
}

.store-admin-page .admin-card .card-body {
    padding: 1rem;
}

.store-admin-page .admin-section-title {
    letter-spacing: 0.08em;
    margin-bottom: 0.75rem;
}

.store-admin-page .admin-shortcuts .admin-tab-shortcut {
    display: inline-flex;
    align-items: center;
    border-color: #cfd7e0;
    color: #334454;
    font-weight: 600;
}

.store-admin-page .admin-tab-shortcut.active {
    background: #233140;
    border-color: #233140;
    color: #fff;
}

.store-admin-page .admin-tab-shortcut.active .badge {
    background: rgba(255, 255, 255, 0.16) !important;
    border-color: rgba(255, 255, 255, 0.34) !important;
    color: #fff !important;
}

.store-admin-page .admin-record {
    border: 1px solid #dde3ea;
    border-radius: 0.65rem;
    background: #fff;
    padding: 0.6rem;
}

.store-admin-page .admin-record + .admin-record {
    margin-top: 0.55rem;
}

.store-admin-page .admin-collapsible > summary {
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
    font-weight: 600;
}

.store-admin-page .admin-collapsible > summary::-webkit-details-marker {
    display: none;
}

.store-admin-page .admin-collapsible[open] > summary {
    margin-bottom: 0.35rem;
}

.store-admin-page .admin-category-metrics {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
    margin-left: 0.45rem;
    vertical-align: middle;
}

.store-admin-page .form-label {
    margin-bottom: 0.2rem;
    font-size: 0.83rem;
    color: #4b5968;
}

.store-admin-page .form-control,
.store-admin-page .form-select {
    font-size: 0.92rem;
}

.store-admin-page .admin-category-tree {
    border-top: 1px dashed #d7dee7;
    margin-top: 0.9rem;
    padding-top: 0.8rem;
}

.store-admin-page .admin-category-tree__section + .admin-category-tree__section {
    margin-top: 0.65rem;
}

.store-admin-page .admin-category-tree__title {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #4f5f71;
    font-weight: 700;
}

.store-admin-page .admin-category-tree__products {
    margin: 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.25rem;
}

.store-admin-page .admin-category-tree__products li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    color: #22313f;
    position: relative;
    border-radius: 0.45rem;
    padding: 0.2rem 0.3rem;
}

.store-admin-page .admin-category-tree__product-name {
    font-size: 0.9rem;
}

.store-admin-page .admin-subcategory-list {
    display: grid;
    gap: 0.5rem;
}

.store-admin-page .admin-collapsible--nested {
    --subcategory-tree-x-head: 1rem;
    --subcategory-tree-x-list: 1rem;
    --subcategory-tree-color: #2e7d66;
    border: 1px solid #d9e2eb;
    border-radius: 0.55rem;
    padding: 0.5rem 0.6rem;
    background: #f8fafc;
}

.store-admin-page .admin-collapsible--nested[open] {
    background: #f3f7fb;
}

.store-admin-page .admin-subcategory-item {
    border: 1px solid #d9e2eb;
    border-radius: 0.55rem;
    padding: 0.55rem 0.6rem;
    background: #f8fafc;
}

.store-admin-page .admin-subcategory-item__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.store-admin-page .admin-subcategory-actions {
    display: flex;
    justify-content: flex-end;
}

.store-admin-page .admin-subcategory-product-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.store-admin-page .admin-subcategory-bulk-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    position: relative;
    padding-left: 0;
}

.store-admin-page .admin-subcategory-bulk-head::before,
.store-admin-page .admin-subcategory-bulk-head::after {
    content: "";
    position: absolute;
    left: calc(var(--subcategory-tree-x-head, 1rem) - 1px);
    background: var(--subcategory-tree-color);
    z-index: 0;
    opacity: 0;
}

.store-admin-page .admin-subcategory-bulk-head::before {
    top: 50%;
    width: 0.62rem;
    height: 2px;
    transform: translateY(-50%);
}

.store-admin-page .admin-subcategory-bulk-head::after {
    top: 50%;
    bottom: -0.35rem;
    width: 2px;
    border-radius: 999px;
}

.store-admin-page .admin-subcategory-bulk-head.admin-subcategory-bulk-head--connected::before,
.store-admin-page .admin-subcategory-bulk-head.admin-subcategory-bulk-head--connected::after {
    opacity: 1;
}

.store-admin-page .admin-subcategory-tree-list {
    position: relative;
}

.store-admin-page .admin-subcategory-tree-list::before {
    content: "";
    position: absolute;
    left: calc(var(--subcategory-tree-x-list, 1rem) - 1px);
    top: -0.35rem;
    bottom: -0.12rem;
    width: 2px;
    border-radius: 999px;
    background: var(--subcategory-tree-color, #2e7d66);
    opacity: 0;
    z-index: 0;
}

.store-admin-page .admin-subcategory-tree-list.admin-subcategory-tree-list--connected::before {
    opacity: 1;
}

.store-admin-page .admin-subcategory-bulk-head .form-check {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding-left: 0;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.store-admin-page .admin-subcategory-bulk-head .form-check-input {
    float: none;
    margin: 0;
}

.store-admin-page .admin-subcategory-bulk-actions {
    display: flex;
    justify-content: flex-end;
}

.store-admin-page .admin-category-tree__products li.admin-subcategory-row--checked {
    background: rgba(41, 115, 94, 0.1);
}

.store-admin-page .admin-category-tree__products li.admin-subcategory-row--checked::before {
    content: none;
}

.store-admin-page .admin-category-tree__products li.admin-subcategory-row--checked::after {
    content: "";
    position: absolute;
    left: calc(var(--subcategory-tree-x-list, 1rem) - 1px);
    top: calc(50% - 0.48rem);
    width: 0.62rem;
    height: 0.48rem;
    border-left: 2px solid var(--subcategory-tree-color, #2e7d66);
    border-bottom: 2px solid var(--subcategory-tree-color, #2e7d66);
    border-bottom-left-radius: 0.42rem;
    z-index: 0;
}

.store-admin-page .admin-category-tree__products li .form-check {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding-left: 0;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.store-admin-page .admin-subcategory-product-checkbox {
    float: none;
    margin: 0;
    position: relative;
    z-index: 2;
}

.store-admin-page .admin-subcategory-tree-list .form-check-input,
.store-admin-page .admin-subcategory-bulk-head .form-check-input {
    width: 1rem;
    height: 1rem;
}

.store-admin-page .admin-confirm-modal .modal-content {
    border: 1px solid #ced8e3;
    border-radius: 0.8rem;
    box-shadow: 0 18px 40px rgba(15, 29, 43, 0.16);
}

.store-admin-page .admin-confirm-modal .modal-header {
    background: linear-gradient(180deg, #f8fbff 0%, #f2f6fb 100%);
    border-bottom-color: #d9e2eb;
}

.store-admin-page .admin-confirm-modal .modal-footer {
    border-top-color: #d9e2eb;
}

/* Admin navbar is sticky with high z-index; ensure modals/backdrops overlay it. */
.store-admin-page .modal {
    z-index: 2205;
}

.store-admin-page .modal-backdrop {
    z-index: 2200;
}

.store-admin-page .admin-bulk-panel {
    border: 1px solid #d9e2eb;
    border-radius: 0.65rem;
    background: #f7fafd;
    padding: 0.75rem;
}

.store-admin-page .admin-bulk-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.store-admin-page .admin-bulk-panel__list {
    max-height: 200px;
    overflow: auto;
    border: 1px solid #dde5ee;
    border-radius: 0.55rem;
    background: #fff;
    padding: 0.5rem;
    display: grid;
    gap: 0.35rem;
}

.store-admin-page .admin-bulk-panel__item {
    margin: 0;
    padding: 0.2rem 0.1rem 0.2rem 1.65rem;
}

.store-admin-page .admin-bulk-panel__item .form-check-input {
    margin-left: -1.45rem;
}

.store-admin-page .admin-bulk-panel__actions {
    display: flex;
    justify-content: flex-end;
}

.store-admin-page .admin-fees-pane .admin-fee-row {
    border: 1px solid #dde3ea;
    border-radius: 0.65rem;
    background: #fff;
    padding: 0.6rem;
}

.store-admin-page .admin-fees-pane .admin-fee-row--add {
    background: #f7fafd;
}

.store-admin-page .admin-fees-pane [data-fee-category-summary] {
    min-height: 1.5rem;
    line-height: 1.25rem;
    display: inline-flex;
    align-items: center;
}

.store-admin-page .admin-fees-pane .admin-fee-action-btn {
    min-height: 2.3rem;
}

.store-admin-page .admin-fees-pane .admin-fee-actions {
    grid-template-columns: 1fr;
}

.store-admin-page .admin-coupon-form {
    border: 1px solid #dde3ea;
    border-radius: 0.7rem;
    background: #fff;
    padding: 0.7rem;
}

.store-admin-page .admin-coupon-form--add {
    background: #f7fafd;
}

.store-admin-page .admin-coupon-form__exclusions {
    border-top: 1px dashed #d8e0e9;
    margin-top: 0.2rem;
    padding-top: 0.6rem;
}

.store-admin-page .admin-coupon-exclusion {
    border: 1px solid #d9e1ea;
    border-radius: 0.6rem;
    background: #fcfdff;
    padding: 0.5rem 0.6rem;
}

.store-admin-page .admin-coupon-exclusion + .admin-coupon-exclusion {
    margin-top: 0.45rem;
}

.store-admin-page .admin-coupon-exclusion > summary {
    cursor: pointer;
    list-style: none;
    font-weight: 700;
    color: #32465a;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.store-admin-page .admin-coupon-exclusion > summary::-webkit-details-marker {
    display: none;
}

.store-admin-page .admin-coupon-exclusion > summary::after {
    content: "+";
    font-weight: 700;
    color: #607386;
}

.store-admin-page .admin-coupon-exclusion[open] > summary::after {
    content: "-";
}

.store-admin-page .admin-dual-list {
    --dual-list-height: 10.5rem;
}

.store-admin-page .admin-dual-list [data-dual-available],
.store-admin-page .admin-dual-list [data-dual-selected] {
    min-height: var(--dual-list-height);
    background: #fbfdff;
    border-color: #d6dee8;
}

.store-admin-page .admin-dual-list [data-dual-available]:focus,
.store-admin-page .admin-dual-list [data-dual-selected]:focus {
    border-color: #8aa7c4;
    box-shadow: 0 0 0 0.2rem rgba(50, 108, 161, 0.14);
}

.store-admin-page .admin-dual-list [data-dual-to-selected],
.store-admin-page .admin-dual-list [data-dual-to-available] {
    min-width: 2rem;
    font-weight: 700;
    line-height: 1;
}

.store-admin-page .admin-dual-list .small.text-muted {
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.7rem;
}

@media (min-width: 768px) {
    .store-admin-page .admin-fees-pane .admin-fee-actions {
        grid-template-columns: 1fr 1fr;
    }
}

