@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
    --clr-espresso: #1e1208;
    --clr-mahogany: #3b1f0e;
    --clr-walnut: #5c3d22;
    --clr-oak: #9c6d3e;
    --clr-gold: #b8923a;
    --clr-gold-light: #d4aa60;
    --clr-wheat: #e8d9c0;
    --clr-linen: #f3ece1;
    --clr-ivory: #faf7f2;
    --clr-white: #ffffff;
    --clr-muted: #8a7560;
    --clr-border: #e0d4c0;
    --clr-success-bg: #ebf5ee;
    --clr-success-txt: #2e6b4a;
    --clr-success-bdr: #b4dfc0;
    --clr-danger-bg: #fbeae7;
    --clr-danger-txt: #8c4a3a;
    --clr-danger-bdr: #e8b8ae;
    --clr-info-bg: #eef3fb;
    --clr-info-txt: #2c4a82;
    --clr-info-bdr: #c0cff0;

    --ff-display: 'Cormorant Garamond', Georgia, serif;
    --ff-body: 'DM Sans', system-ui, sans-serif;

    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 14px;
    --radius-xl: 20px;

    --shadow-sm: 0 2px 8px rgba(30, 18, 8, .08);
    --shadow-md: 0 10px 24px rgba(30, 18, 8, .12);
    --shadow-lg: 0 18px 40px rgba(30, 18, 8, .16);
    --shadow-3d: 0 30px 55px rgba(30, 18, 8, .20);

    --ease-out: cubic-bezier(.22, .68, 0, 1.2);
    --ease-std: cubic-bezier(.4, 0, .2, 1);
}

.wsd-page {
    font-family: var(--ff-body);
    color: var(--clr-espresso);
    background:
        radial-gradient(1200px 560px at 8% -18%, rgba(212, 170, 96, .15), transparent 55%),
        radial-gradient(1000px 540px at 96% -24%, rgba(30, 18, 8, .08), transparent 60%),
        var(--clr-ivory);
    padding: 2.2rem 0 5rem;
}

.wsd-breadcrumb {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .73rem;
    font-weight: 500;
    letter-spacing: .04em;
    color: var(--clr-muted);
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.wsd-breadcrumb a {
    color: var(--clr-muted);
    text-decoration: none;
    transition: color .18s;
}

.wsd-breadcrumb a:hover {
    color: var(--clr-oak);
}

.wsd-breadcrumb .sep {
    color: var(--clr-wheat);
    font-size: .65rem;
}

.wsd-breadcrumb .current {
    color: var(--clr-espresso);
    font-weight: 700;
}

.wsd-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.1rem;
    align-items: start;
}

.wsd-gallery {
    position: sticky;
    top: 1.3rem;
}

.wsd-main-img-wrap {
    --wsd-tilt-x: 0deg;
    --wsd-tilt-y: 0deg;
    position: relative;
    background: linear-gradient(145deg, #f8f2e8 0%, #efe2cf 100%);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    aspect-ratio: 16 / 11;
    margin-bottom: .9rem;
    transform-style: preserve-3d;
    perspective: 1200px;
    box-shadow: var(--shadow-lg);
    transition: transform .26s var(--ease-std), box-shadow .26s var(--ease-std);
}

.wsd-main-img-wrap:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-3d);
}

.wsd-main-img-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(130deg, rgba(255, 255, 255, .35), rgba(255, 255, 255, 0) 42%);
    pointer-events: none;
    z-index: 2;
}

.wsd-main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    background: transparent;
    padding: 0;
    display: block;
    will-change: transform, opacity;
    transform: rotateX(var(--wsd-tilt-x)) rotateY(var(--wsd-tilt-y)) translateZ(20px);
    transition: opacity .3s var(--ease-std), transform .22s var(--ease-std);
}

.wsd-main-img.is-transitioning {
    opacity: 0;
    transform: scale(.98) translateZ(10px);
}

.wsd-main-img-fallback {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--clr-wheat);
    gap: .5rem;
    background: var(--clr-linen);
}

.wsd-main-img-fallback i {
    font-size: 2.7rem;
}

.wsd-main-img-fallback span {
    font-size: .8rem;
    color: var(--clr-muted);
}

.wsd-zoom-hint {
    position: absolute;
    bottom: .8rem;
    right: .8rem;
    background: rgba(250, 247, 242, .9);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-md);
    padding: .28rem .6rem;
    font-size: .63rem;
    font-weight: 700;
    color: var(--clr-muted);
    letter-spacing: .07em;
    text-transform: uppercase;
    backdrop-filter: blur(3px);
    display: flex;
    align-items: center;
    gap: .25rem;
    pointer-events: none;
    opacity: 0;
    z-index: 3;
    transition: opacity .2s;
}

.wsd-main-img-wrap:hover .wsd-zoom-hint {
    opacity: 1;
}

.wsd-thumbs {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

.wsd-thumb {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 2px solid var(--clr-border);
    background: var(--clr-white);
    cursor: pointer;
    transition: border-color .2s var(--ease-std), box-shadow .2s var(--ease-std), transform .2s var(--ease-out);
    flex-shrink: 0;
}

.wsd-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    background: var(--clr-white);
    display: block;
}

.wsd-thumb:hover {
    border-color: var(--clr-gold);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.wsd-thumb.active {
    border-color: var(--clr-espresso);
    box-shadow: 0 0 0 3px rgba(30, 18, 8, .12);
}

.wsd-thumb:focus-visible {
    outline: 2px solid var(--clr-gold);
    outline-offset: 2px;
}

.wsd-info {
    background: rgba(255, 255, 255, .7);
    border: 1px solid rgba(224, 212, 192, .9);
    border-radius: var(--radius-xl);
    padding: 1.15rem 1.15rem 1.35rem;
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(2px);
}

.wsd-category {
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--clr-gold);
    margin-bottom: .45rem;
}

.wsd-product-name {
    font-family: var(--ff-display);
    font-size: clamp(1.75rem, 3.2vw, 2.4rem);
    font-weight: 700;
    line-height: 1.08;
    letter-spacing: -.01em;
    color: var(--clr-espresso);
    margin: 0 0 .8rem;
}

.wsd-price-row {
    display: flex;
    align-items: center;
    gap: .8rem;
    flex-wrap: wrap;
    margin-bottom: .9rem;
}

.wsd-price {
    font-family: var(--ff-display);
    font-size: 1.8rem;
    font-weight: 600;
    color: var(--clr-espresso);
    line-height: 1;
}

.wsd-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .64rem;
    font-weight: 700;
    letter-spacing: .09em;
    text-transform: uppercase;
    padding: .32rem .75rem;
    border-radius: 99px;
    border: 1px solid transparent;
}

.wsd-badge-stock { background: var(--clr-success-bg); color: var(--clr-success-txt); border-color: var(--clr-success-bdr); }
.wsd-badge-out { background: var(--clr-danger-bg); color: var(--clr-danger-txt); border-color: var(--clr-danger-bdr); }
.wsd-badge-custom { background: var(--clr-info-bg); color: var(--clr-info-txt); border-color: var(--clr-info-bdr); }

.wsd-rating {
    display: flex;
    align-items: center;
    gap: .55rem;
    margin-bottom: .95rem;
    padding-bottom: .95rem;
    border-bottom: 1px solid var(--clr-border);
}

.wsd-stars { display: inline-flex; gap: 2px; font-size: .82rem; }
.wsd-stars .filled { color: var(--clr-gold); }
.wsd-stars .half { color: var(--clr-gold-light); }
.wsd-stars .empty { color: var(--clr-wheat); }

.wsd-rating-label {
    font-size: .75rem;
    color: var(--clr-muted);
    font-style: italic;
}

.wsd-short-desc {
    font-size: .9rem;
    line-height: 1.68;
    color: var(--clr-walnut);
    margin-bottom: 1.15rem;
    max-width: 64ch;
}

.wsd-custom-callout {
    background: linear-gradient(135deg, var(--clr-linen) 0%, #ede5d3 100%);
    border: 1px solid var(--clr-wheat);
    border-radius: var(--radius-lg);
    padding: 1.1rem 1.2rem;
    margin-bottom: 1.2rem;
}

.wsd-custom-callout-title {
    font-family: var(--ff-display);
    font-size: 1.08rem;
    font-weight: 700;
    color: var(--clr-espresso);
    margin-bottom: .35rem;
}

.wsd-custom-callout-desc {
    font-size: .84rem;
    color: var(--clr-muted);
    line-height: 1.58;
    margin-bottom: .8rem;
}

.wsd-actions-box {
    background: var(--clr-white);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-xl);
    padding: 1.15rem;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-md);
}

.wsd-qty-label {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--clr-muted);
    margin-bottom: .45rem;
}

.wsd-qty-wrap {
    display: inline-flex;
    align-items: center;
    border: 1.5px solid var(--clr-border);
    border-radius: var(--radius-md);
    background: var(--clr-linen);
    overflow: hidden;
    margin-bottom: .9rem;
}

.wsd-qty-btn {
    width: 38px;
    height: 38px;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--clr-walnut);
    transition: background .18s, color .18s;
    user-select: none;
    flex-shrink: 0;
}

.wsd-qty-btn:hover:not(:disabled) {
    background: var(--clr-wheat);
    color: var(--clr-espresso);
}

.wsd-qty-btn:disabled { opacity: .35; cursor: not-allowed; }

.wsd-qty-input {
    width: 56px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--clr-border);
    border-right: 1px solid var(--clr-border);
    background: var(--clr-white);
    font-family: var(--ff-body);
    font-size: .9rem;
    font-weight: 600;
    color: var(--clr-espresso);
    padding: 0;
    height: 38px;
    -moz-appearance: textfield;
    appearance: textfield;
}

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

.wsd-qty-input:focus { outline: none; background: #fff; }

.wsd-btn-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    font-family: var(--ff-body);
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    border-radius: var(--radius-md);
    border: 2px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: all .2s var(--ease-std);
    padding: .68rem 1rem;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
}

.wsd-btn-cta:disabled,
.wsd-btn-cta[disabled] { opacity: .45; cursor: not-allowed; pointer-events: none; }

.wsd-btn-primary { background: var(--clr-espresso); color: var(--clr-ivory); border-color: var(--clr-espresso); }

.wsd-btn-primary:hover:not(:disabled) {
    background: var(--clr-mahogany);
    border-color: var(--clr-mahogany);
    color: var(--clr-ivory);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.wsd-btn-secondary { background: var(--clr-white); color: var(--clr-walnut); border-color: var(--clr-walnut); }

.wsd-btn-secondary:hover:not(:disabled) {
    background: var(--clr-walnut);
    color: var(--clr-ivory);
    transform: translateY(-1px);
}

.wsd-btn-gold { background: var(--clr-gold); color: var(--clr-white); border-color: var(--clr-gold); flex: 2; }

.wsd-btn-gold:hover {
    background: var(--clr-gold-light);
    border-color: var(--clr-gold-light);
    color: var(--clr-white);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.wsd-cta-row {
    display: flex;
    gap: .55rem;
    flex-wrap: nowrap;
}

.wsd-btn-back {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--clr-muted);
    text-decoration: none;
    margin-top: .65rem;
    transition: color .18s;
}

.wsd-btn-back:hover { color: var(--clr-espresso); }

.wsd-trust-strip {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .45rem;
    padding: .75rem .9rem;
    background: var(--clr-linen);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    margin-bottom: 1rem;
}

.wsd-trust-item { display: flex; align-items: center; gap: .4rem; }

.wsd-trust-icon {
    width: 26px;
    height: 26px;
    background: var(--clr-white);
    border: 1px solid var(--clr-border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .72rem;
    color: var(--clr-gold);
    flex-shrink: 0;
}

.wsd-trust-text {
    font-size: .67rem;
    font-weight: 500;
    color: var(--clr-walnut);
    line-height: 1.2;
}

.wsd-accordion {
    border-top: 1px solid var(--clr-border);
    margin-top: 1.6rem;
}

.wsd-accordion-item { border-bottom: 1px solid var(--clr-border); }

.wsd-accordion-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: none;
    border: none;
    padding: .95rem 0;
    cursor: pointer;
    text-align: left;
    font-family: var(--ff-display);
    font-size: 1.02rem;
    font-weight: 700;
    color: var(--clr-espresso);
    transition: color .18s;
}

.wsd-accordion-btn:hover { color: var(--clr-oak); }

.wsd-accordion-btn:focus-visible {
    outline: 2px solid var(--clr-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

.wsd-accordion-icon {
    width: 25px;
    height: 25px;
    border-radius: 50%;
    background: var(--clr-linen);
    border: 1px solid var(--clr-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .68rem;
    color: var(--clr-muted);
    flex-shrink: 0;
    transition: transform .28s var(--ease-std), background .18s;
}

.wsd-accordion-btn[aria-expanded='true'] .wsd-accordion-icon {
    transform: rotate(45deg);
    background: var(--clr-espresso);
    color: var(--clr-ivory);
    border-color: var(--clr-espresso);
}

.wsd-accordion-body {
    padding: 0 0 .95rem;
    display: none;
    animation: wsd-fade-in .2s ease;
}

.wsd-accordion-body.is-open { display: block; }

@keyframes wsd-fade-in {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 1; transform: translateY(0); }
}

.wsd-desc-text {
    font-size: .88rem;
    line-height: 1.66;
    color: var(--clr-walnut);
}

.wsd-specs-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0;
}

.wsd-spec-row { display: contents; }

.wsd-spec-row > * {
    padding: .58rem .2rem;
    font-size: .84rem;
    border-bottom: 1px solid var(--clr-border);
}

.wsd-spec-key {
    color: var(--clr-muted);
    font-weight: 600;
    padding-right: 1.3rem;
    white-space: nowrap;
}

.wsd-spec-val {
    color: var(--clr-espresso);
    font-weight: 400;
    margin: 0;
}

.wsd-reviews-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.7rem .85rem;
    background: var(--clr-linen);
    border: 1px dashed var(--clr-wheat);
    border-radius: var(--radius-lg);
}

.wsd-reviews-placeholder i {
    font-size: 1.85rem;
    color: var(--clr-wheat);
    margin-bottom: .6rem;
}

.wsd-reviews-placeholder h4 {
    font-family: var(--ff-display);
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: .3rem;
}

.wsd-reviews-placeholder p {
    font-size: .8rem;
    color: var(--clr-muted);
    max-width: 42ch;
    line-height: 1.5;
    margin: 0;
}

.wsd-coming-soon-badge {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: .24rem .62rem;
    border-radius: 99px;
    background: #ede5d8;
    color: var(--clr-walnut);
    border: 1px solid var(--clr-wheat);
    margin-bottom: .7rem;
}

.wsd-sticky-bar {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 900;
    background: var(--clr-white);
    border-top: 1px solid var(--clr-border);
    padding: .7rem 1rem;
    gap: .5rem;
    box-shadow: 0 -6px 24px rgba(30, 18, 8, .12);
}

.wsd-form-contents { display: contents; }
.wsd-flex-1 { flex: 1; }
.wsd-flex-2 { flex: 2; }

@media (max-width: 991px) {
    .wsd-layout {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .wsd-gallery { position: static; }

    .wsd-main-img-wrap {
        aspect-ratio: 16 / 11;
        box-shadow: var(--shadow-md);
    }

    .wsd-main-img {
        transform: none;
    }

    .wsd-cta-row { flex-wrap: wrap; }

    .wsd-btn-cta { flex: 1 1 calc(50% - .3rem); }

    .wsd-sticky-bar {
        display: flex;
        align-items: center;
    }

    .wsd-actions-box { padding-bottom: 4.6rem; }
}

@media (max-width: 575px) {
    .wsd-page { padding: 1.2rem 0 4rem; }

    .wsd-breadcrumb { margin-bottom: 1rem; }

    .wsd-product-name { font-size: 1.55rem; }

    .wsd-price { font-size: 1.35rem; }

    .wsd-info {
        padding: .9rem .85rem 1.05rem;
    }

    .wsd-trust-strip { grid-template-columns: 1fr; }

    .wsd-thumb {
        width: 56px;
        height: 56px;
    }

    .wsd-cta-row { flex-direction: column; }

    .wsd-btn-cta {
        flex: none;
        width: 100%;
    }

    .wsd-main-img-wrap {
        aspect-ratio: 16 / 11;
        border-radius: var(--radius-lg);
    }

    .wsd-main-img {
        padding: 0;
    }
}
