body:has(dialog[open]) {
  overflow: hidden;
}

.PD-container .modal {

    position: relative;

    width: 100vw;

    background: rgba(0, 0, 0, .2);

    backdrop-filter: blur(10px);

    position: absolute;

}

.PD-container .modal-header {

    position: absolute;

    /*top:10px;*/

    z-index: 10;

    width: 100%;

    justify-content: end;

    background: rgba(255, 255, 255, .4);

    backdrop-filter: blur(10px);

}

.modal-title {

    font-family: "inter", sans-serif;

    color: white;

}

.modal-fullscreen .modal-body {

    overflow-y: unset !important;

    /*display: grid;*/

    place-content: center;

    height: 100vh;

    width: 100vw;

    overflow: hidden;

    background: #333333b0;

}



.PD-container .modal-content {

    background: none;

}



/* Disable pointer events on the page container */





g {

    pointer-events: auto;

}





/* Main Layout */

.PD-container {

    display: flex;

    flex-direction: column;

    width: 100%;

    align-items: center;

    padding-top: 54px;



}



.PD-container .product-details * {

    font-family: "inter", sans-serif !important;

}



.PD-container .content-wrapper {

    display: flex;

    flex-direction: column;

    align-items: center;

    gap: 18px;

    padding: 31px;

    width: 100%;



}



/* Product Section */

.PD-container .product-section {

    display: flex;

    flex-direction: column;

    gap: 48px;

    max-width: 1200px;

    width: 100%;

}



@media (min-width: 768px) {

    .PD-container .product-section {

        flex-direction: row;

    }

}



/* Product Images */





.PD-container .producttt-container {

    display: flex;

    

width: 220px;



    gap: 40px;

    flex-wrap: wrap;



    border-radius: 12px;

}



.PD-container .producttt-container,
.opened-book .book-hovering, .svg-modal-button, dialog form button {

    animation: scaleOut 0.3s ease-in-out forwards;

}



.PD-container .producttt-container:hover,
.opened-book .book-hovering:hover, .svg-modal-button:hover, dialog form button:hover {

    animation: scaleIn 0.3s ease-in-out forwards;

}







.PD-container .image-gallery {

    flex: 1;

    /*min-width: 280px;*/

    max-width: 400px;

    position: sticky;

    top: 20px;

    height: fit-content;

}



.PD-container .image-gallery img {

    width: 100%;

    border-radius: 12px;

    margin-bottom: 0px;

    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.1);

    transition: transform 0.3s ease;

}



.PD-container .image-gallery img:hover {

    transform: scale(1.02);

}



.PD-container .producttt-container .book-wrapper {

    position: relative;

    width: 220px;
    min-height: 270px;

}



.PD-container .producttt-container .back-cover {

    position: absolute;

    width: 96%;

    height: 96%;

    top: 2%;

    left: 2%;

    /* background: #111; */

    border-radius: 0 6px 6px 0;

    z-index: -10;

}



.PD-container .producttt-container .pages {

    position: absolute;

    width: 90%;

    height: 94%;

    top: 3%;

    left: 5%;

    z-index: 0;

}



.PD-container .producttt-container .page {

    position: absolute;

    top: 0;

    right: 0;

    width: 98%;

    height: 100%;

    background: white;

    border: 1px solid rgba(0, 0, 0, 0.2);

    border-radius: 0 6px 6px 0;

    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);

    transform-origin: right center;

    z-index: -5;

}



.PD-container .producttt-container .cover-image {

    position: relative;

    border-radius: 2px 6px 6px 2px;

    /* box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15); */

    transform-style: preserve-3d;

    transform-origin: left center;

    z-index: 10;

    display: flex;

}



.PD-container .shine-effect {

    position: absolute;

    width: 20px;

    height: 100%;

    top: 0;

    margin-left: 16px;

    border-left: 2px solid #00000010;

    background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));

    z-index: 5;

}



.PD-container .light-effect {

    position: absolute;

    width: 100%;

    height: 100%;

    top: 0;

    left: 0;

    border-radius: 2px 6px 6px 2px;

    background-image: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.5));

    opacity: 0.15;

    z-index: 4;

    mix-blend-mode: overlay;

}



.PD-container .hover-area {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    z-index: 20;

    cursor: pointer;

}



.PD-container .play-button {

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%);

    z-index: 30;

    cursor: pointer;

    animation: pulse 2s infinite ease-in-out;

}



@keyframes pulse {

    0% {

        transform: translate(-50%, -50%) scale(1);

        opacity: 1;

    }



    50% {

        transform: translate(-50%, -50%) scale(1.1);

        opacity: 0.8;

    }



    100% {

        transform: translate(-50%, -50%) scale(1);

        opacity: 1;

    }

}



.PD-container .product-images {

    display: flex;

    flex-direction: column;

    border-radius: 12px;

    overflow: hidden;

    padding-left: 20%;

}



.PD-container .product-image {

    width: 100%;

    max-width: 334px;

    height: auto;

    display: block;

}



/* Product Details */

.PD-container .product-details {

    flex: 1;



}



/* Product Header */

.PD-container .product-header {

    /*margin-bottom: 32px;*/

    padding: 24px;

    width: 100%;

    box-shadow: 0 1px 3px rgba(255, 50, 50, 1);
    border-radius: 16px;

    border-radius: 16px;

    background: white;

}



/* Tags */

.PD-container .tags-container {

    display: flex;

    flex-wrap: wrap;

    align-items: center;

    gap: 10px;

    margin-bottom: 16px;



}



.PD-container .tag {

    background-color: #ffdfda;

    color: var(--baseblack);

    border-radius: 20px;

    padding: 4px 12px;

    font-size: 14px;

    font-weight: 500;

    font-family: "inter", sans-serif !important;

    cursor: pointer;

}



.PD-container .tags-label {

    display: inline-flex;

    align-items: center;

    gap: 4px;

    padding: 3px 6px;

    background-color: #f2f2f2;

    border-radius: 20px;

    font-size: 12px;

    font-family: "inter", sans-serif !important;

}



.PD-container .tag-icon {

    width: 12px;

    height: 12px;

}



/* Product Title */

.PD-container .product-title {

    font-family: "inter", sans-serif;

    font-size: 20px;

    /*font-weight: 600;*/

    color: var(--baseblack);

    margin-bottom: 16px;

    line-height: 1.4;

}



.PD-container .product-title span {

    color: #0087ff;

    font-weight: 600;

}



/* Ratings */

.PD-container .ratings-container {

    display: flex;

    align-items: center;

    gap: 12px;

    margin-bottom: 16px;

}



.PD-container .stars {

    display: flex;

}



.star {

    color: #fbbf24;

    font-size: 20px;

}



.PD-container .reviews-link {

    color: var(--primaryblue);

    font-weight: 500;

    text-decoration: underline;

}



/* Price and Buy Button */

.PD-container .price-buy-container {

    display: flex;

    align-items: center;

    gap: 40px;

    flex-wrap: wrap;

    justify-content: space-between;

}



.PD-container .price {

    font-size: 24px;

    font-weight: 600;

    color: var(--baseblack);

}



.PD-container .combo-items-list .image-wrapper {

    max-width: 100px;



}



.PD-container .combo-items-list {

    align-self: center;

}







.PD-container .combo-items-list img {

    width: 100%;

    padding: 8px;

    border: 1px solid #ddd;

    border-radius: 8px;

    transform: scale(1);

    transition: transform .2s ease;

}



.PD-container .combo-items-list .image-wrapper.active img {

    max-width: 100px;

    border: .5px solid var(--orange);



}



.PD-container .combo-items-list .image-wrapper.active .menu-title {

    color: var(--orange);

}



.PD-container .combo-items-list .menu-title {

    font-size: 12px;

    text-align: center;

}



.PD-container .combo-items-list img:hover {

    transform: scale(1.03);

}







/* Section Titles */

.PD-container .section-title {

    font-size: 18px;

    font-weight: 500;

    color: #6f6f6f;

    margin-bottom: 20px;

    text-align: start;

}



/* Product Description */

.PD-container .product-description,
.PD-container .about-author,
.PD-container .book-image-wrapper-section {

    /*margin-bottom: 32px;*/

    padding: 24px;



}









.PD-container .description-content {

    display: flex;

    flex-direction: column;

    gap: 16px;

    margin-bottom: 20px;

}



/*@media (min-width: 768px) {

    .PD-container .description-content {

        flex-direction: row;

    }

}*/



/* Author Info */

.PD-container .author-info {

    display: flex;

    gap: 20px;

    justify-content: space-between;

    border: 1px solid #ececec;

    padding: 8px;

    border-radius: 12px;

    min-width: 200px;

    height: fit-content;

}



.PD-container .author-detail {

    font-size: 14px;

    color: var(--baseblack);

    margin-bottom: 8px;

}



.PD-container .author-detail:last-child {

    margin-bottom: 0;

}



.PD-container .label {

    font-weight: 700;

    color: #2c2524;

}



/* Product Specifications */

.PD-container .product-specs {

    display: flex;

    flex: 1;

    gap: 12px;

    flex-wrap: wrap;

}



.PD-container .spec-item {

    display: flex;

    flex-direction: column;

    align-items: center;

    gap: 4px;

    flex: 1;

}



.PD-container .spec-icon {

    display: flex;

    align-items: center;

    justify-content: center;

    height: 67px;

    width: 100%;

    border-radius: 8px;

    border: 1px solid #d6d6d6;

    min-width: 70px;

}



.spec-icon img {

    max-width: 70px;

    max-height: 70px;

}



.PD-container .spec-label {

    font-size: 12px;

    text-align: center;

    color: var(--baseblack);

    white-space: pre-line;

}



/* Custom Icons */

.PD-container .book-icon .book-shape {

    position: relative;

    width: 30px;

    height: 36px;

    background-color: var(--basewhite);

    border-radius: 2.61px 9.12px 2.61px 2.61px;

    border: 0.65px solid #ff3131;

}



.PD-container .book-lines {

    position: absolute;

    top: 14px;

    left: 7px;

    display: flex;

    flex-direction: column;

    gap: 3.91px;

}



.PD-container .line {

    width: 16px;

    height: 1px;

    background-color: #ccc;

}



.PD-container .book-corner {

    position: absolute;

    width: 7px;

    height: 7px;

    top: 0;

    right: 0;

    background-color: #e3e3e3;

    border: 0.65px solid #ff3131;

}



.PD-container .dimension-icon .dimension-shape {

    position: relative;

    width: 36px;

    height: 40px;

}



.PD-container .dimension-box {

    position: absolute;

    width: 27px;

    height: 32px;

    border-radius: 2.61px;

    border: 0.65px solid #ff3131;

    background-color: var(--basewhite);

}



.PD-container .dimension-box.back {

    top: 3px;

    left: 3px;

}



.PD-container .dimension-box.front {

    top: 0;

    left: 0;

}



.PD-container .dimension-line.vertical {

    position: absolute;

    width: 1px;

    height: 30px;

    background-color: #ccc;

    top: 1px;

    left: 0;

}



.PD-container .dimension-line.horizontal {

    position: absolute;

    width: 24px;

    height: 1px;

    background-color: #ccc;

    bottom: 0;

    left: 7px;

}



.PD-container .age-icon .age-circle {

    position: relative;

    width: 42px;

    height: 42px;

    border-radius: 50%;

    border: 2px solid var(--secondaryorange);

    display: flex;

    align-items: center;

    justify-content: center;

    background-color: var(--basewhite);

}



.PD-container .age-text {

    font-size: 15.7px;

    color: var(--secondaryorange);

    font-weight: normal;

}



.PD-container .age-plus {

    position: absolute;

    top: 3px;

    right: 8px;

    font-size: 10.4px;

    color: var(--secondaryorange);

    font-weight: normal;

}



/* Description Text */

.PD-container .description-text {

    font-size: 12px;

    color: var(--baseblack);

}



.PD-container .description-text p {

    margin-bottom: 16px;

}



.PD-container .description-text p:last-child {

    margin-bottom: 0;

}



/* About Author */



.PD-container .author-text {

    font-size: 12px;

    color: var(--baseblack);

}



.PD-container .author-text p {

    margin-bottom: 16px;

}



.PD-container .author-text p:last-child {

    margin-bottom: 0;

}



/* Ratings and Reviews */

.PD-container .ratings-reviews {

    display: flex;

    flex-direction: column;

    gap: 48px;

}



@media (min-width: 768px) {

    .PD-container .ratings-reviews {

        flex-direction: row;

    }

}



/* Ratings Section */

.PD-container .ratings-section {

    display: flex;

    flex-direction: column;

    gap: 32px;

}



.PD-container .rating-summary {

    display: flex;

    flex-direction: column;

    gap: 12px;

}



.PD-container .rating-score {

    font-size: 18px;

    font-weight: 600;

    color: var(--baseblack);

}



.PD-container .rating-bars {

    display: flex;

    flex-direction: column;

    gap: 10px;

    width: 207px;

}



.PD-container .rating-bar {

    display: flex;

    align-items: center;

    gap: 10px;

}



.PD-container .rating-star-label {

    display: flex;

    width: 31px;

    align-items: center;

    justify-content: space-between;

}



.PD-container .rating-star-label span:first-child {

    font-size: 12px;

    font-weight: 600;

    color: var(--baseblack);

}



.PD-container .rating-star-label .star {

    font-size: 20px;

    color: #fbbf24;

}



.PD-container .progress-bar {

    flex: 1;

    height: 10px;

    background-color: #e3e3e3;

    border-radius: 5px;

    overflow: hidden;

}



.PD-container .progress-fill {

    height: 100%;

    background-color: var(--primaryorange);

    border-radius: 5px;

    transition: width 0.3s ease;

}



/* Write Review */

.PD-container .write-review {

    display: flex;

    flex-direction: column;

    gap: 12px;

}



.PD-container .review-title {

    font-size: 18px;

    font-weight: 600;

    color: var(--baseblack);

    text-align: center;

}



.PD-container .review-subtitle {

    font-size: 12px;

    font-weight: 600;

    color: var(--baseblack);

    text-align: center;

}



.PD-container .write-review-button {

    width: 100%;

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 10px;

    padding: 8px;

    border-radius: 20px;

    border: 1px solid #c0c0c0;

    background-color: white;

    cursor: pointer;

    transition: background-color 0.2s;

}



.PD-container .write-review-button:hover {

    background-color: #f9f9f9;

}



.PD-container .write-review-button span {

    font-weight: 600;

    color: var(--baseblack);

}



.PD-container .write-review-button img {

    width: 24px;

    height: 24px;

}



/* Reviews Section */

.PD-container .reviews-section {

    flex: 1;

}



.PD-container .review-cards {

    display: flex;

    flex-direction: column;

    gap: 12px;

}



.PD-container .review-card {

    display: flex;

    gap: 8px;

    padding: 20px;

    border-radius: 12px;

    border: 0.5px solid #dbdbdb;

    background-color: white;

}



.PD-container .reviewer-info {

    display: flex;

    flex-direction: column;

    align-items: center;

    width: 82px;

    gap: 4px;

}



.PD-container .reviewer-avatar {

    width: 43px;

    height: 43px;

    border-radius: 50%;

    object-fit: cover;

}



.PD-container .reviewer-name {

    font-size: 16px;

    font-weight: 600;

    color: var(--baseblack);

    text-align: center;

}



.PD-container .reviewer-stars {

    display: flex;

    align-items: center;

}



.PD-container .reviewer-stars .star {

    font-size: 16px;

    color: #fbbf24;

}



.PD-container .review-text {

    flex: 1;

    font-size: 16px;

    font-weight: normal;

    color: var(--baseblack);

    font-family: 'Playfair Display', serif;

    line-height: 1.5;

}



/* More Like This Section */

.PD-container .more-like-this {

    display: flex;

    flex-direction: column;



    max-width: 1200px;

    width: 100%;

}



.PD-container .product-cards {

    display: flex;

    gap: 24px;



    padding-bottom: 16px;

}



.PD-container .product-card {

    display: flex;

    flex-direction: column;

    width: 405px;

    min-width: 350px;

    background-color: var(--basewhite);

    border-radius: 32px;

    border: 0.5px solid rgba(0, 0, 0, 0.1);

    padding: 16px;

    gap: 9px;

}



.PD-container .product-card-image {

    position: relative;

    height: 257px;

    width: 100%;

    background-color: #c7c7c7;

    border-radius: 16px;

    overflow: hidden;

    display: flex;

    align-items: center;

    justify-content: center;

}



.PD-container .product-card-image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}



.PD-container .discount-badge {

    position: absolute;

    top: 0;

    right: 0;

    height: 40px;

    padding: 0 12px;

    background-color: var(--basewhite);

    color: #2c2524;

    border-radius: 0 16px 0 16px;

    border: 1px solid #ff3131;

    display: flex;

    align-items: center;

    gap: 2px;

}



.PD-container .discount-percent {

    font-size: 16px;

}



.PD-container .discount-text {

    font-size: 12px;

}



.PD-container .product-card-content {

    display: flex;

    align-items: flex-start;

    justify-content: space-between;

    padding: 0 12px;

    width: 100%;

}



.PD-container .product-card-info {

    display: flex;

    flex-direction: column;

    align-items: flex-start;

    gap: 10px;

}



.PD-container .product-card-title {

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 10px;

}



.PD-container .product-card-title h3 {

    font-size: 18px;

    font-weight: 600;

    color: var(--baseblack);

    white-space: nowrap;

}



.PD-container .product-card-details {

    display: flex;

    flex-direction: column;

    align-items: flex-start;

    gap: 4px;

}



.PD-container .product-type {

    font-size: 12px;

    font-weight: 500;

    color: var(--baseblack);

    white-space: nowrap;

}



.PD-container .product-stars {

    display: flex;

    align-items: center;

    width: 98.4px;

}



.PD-container .product-stars img {

    width: 19.2px;

    height: 19.2px;

}



.PD-container .product-card-price {

    display: flex;

    flex-direction: column;

    align-items: center;

    gap: 8px;

}



.PD-container .current-price {

    font-size: 24px;

    font-weight: 600;

    color: var(--secondaryorange);

    white-space: nowrap;

}



.PD-container .original-price {

    font-size: 20px;

    font-weight: 500;

    color: rgba(0, 0, 0, 0.2);

    text-decoration: line-through;

    white-space: nowrap;

}



.PD-container .product-card-buttons {

    display: flex;

    align-items: flex-start;

    gap: 19px;

    width: 100%;

    margin-top: 16px;

}



.PD-container .buy-now-btn {

    flex: 1;

    background-color: var(--secondaryorange);

    color: var(--basewhite);

    font-weight: 600;

    padding: 12px;

    border: none;

    border-radius: 6px;

    cursor: pointer;

    transition: background-color 0.2s;

}



.PD-container .buy-now-btn:hover {

    background-color: #e63946;

}



.PD-container .add-to-cart-btn {

    width: 151.31px;

    background-color: var(--basewhite);

    border: 1px solid var(--secondaryblue);

    color: var(--secondaryblue);

    font-weight: 600;

    padding: 12px;

    border-radius: 6px;

    cursor: pointer;

    display: flex;

    align-items: center;

    gap: 10px;

    justify-content: center;

    transition: background-color 0.2s;

}



.PD-container .add-to-cart-btn:hover {

    background-color: #f0f8ff;

}



/* Responsive Design */

@media (max-width: 768px) {

    .PD-container .content-wrapper {

        padding: 16px;

    }







    .PD-container .price-buy-container {

        gap: 20px;

    }



    .PD-container .description-content {

        flex-direction: column;

    }



    .PD-container .product-specs {

        flex-wrap: wrap;

    }



    .PD-container .spec-item {

        min-width: 60px;

    }



    .PD-container .ratings-reviews {

        flex-direction: column;

    }



    .PD-container .product-cards {

        gap: 16px;

    }



    .PD-container .product-card {

        min-width: 300px;

    }

}



@media (max-width: 480px) {

    .PD-container .product-card-buttons {

        flex-direction: column;

        gap: 12px;

    }



    .PD-container .add-to-cart-btn {

        width: 100%;

    }



    .PD-container .product-specs {

        gap: 8px;

    }



    .PD-container .spec-icon {

        height: 50px;

    }



    .PD-container .spec-label {

        font-size: 8px;

    }

    .PD-container .product-title {

        font-size: 12px;

    }



    .PD-container .tag {

        font-size: 12px;

    }

}



.no-selection {

    -webkit-touch-callout: none;

    -webkit-user-select: none;

    -khtml-user-select: none;

    -moz-user-select: none;

    -ms-user-select: none;

    user-select: none;

}

.opened-book {

    justify-self: center;

}



.opened-book {

    display: flex;

    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);

    border: 1px solid #aaa;

    height: fit-content !important;

    width: 100%;
}

.opened-book img {
    width: 50%;
}


.PD-container dialog {
    position: fixed;
    width: 60%;
    align-self: center;
    justify-self: center;
    height: fit-content;
    border: unset;
    overflow: unset;
    padding: unset;
}

.PD-container dialog::backdrop{
    background-color: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(20px);
}

.PD-container dialog form{
    position: absolute;
    width: fit-content;
    top: 50%;
    right: -70px;
}

.PD-container dialog form button{
    
    padding: 8px 12px;
    font-size: 24px;
    border: unset;
    border-radius: 60px;
    color: rgb(255, 255, 255);
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
    background: linear-gradient(90deg, rgba(255, 50, 50, 1) 0%, rgba(255, 153, 0, 1) 100%);
    border: 3px solid rgb(255, 255, 255);
}
 


.svg-modal-button {
    font-size: 16px;
    padding: 8px 16px;
    color: rgb(0, 0, 0);
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
    background: #fff;
    border: 3px solid rgb(255, 255, 255);
    border-radius: 16px;
    font-weight: 700;
    cursor: pointer;
    margin: 5px;
    width: 220px;
    
    text-wrap: nowrap;
}

.svg-modal-button p{
    font-family: 'inter', sans-serif;
    font-weight: 400;

}
.svg-modal-button img{
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
    height: 115.47px;
}

.svg-modal {

    background-color: unset;
    border: unset;
}

.svg-modal p {
    display: flex;
    width: 100%;
}

.svg-modal object {
    width: 50%;
    background-color: rgb(255, 255, 255);
    /* min-height: 400px; */
}

@media (max-width:1440px){
    .PD-container dialog {
        width: 60%;
        align-self: center;
        justify-self: center;
    }

}
@media (max-width:768px){
    .PD-container dialog {
        width: 90%;
        align-self: center;
        justify-self: center;
    }
    .PD-container dialog form{
            top: 102%;
            right: 46%;
    }

}

@media (max-width:600px){

    .PD-container dialog form{
            top: 105%;
            right: 42.5%;
    }
    .PD-container dialog form button{
            font-size: 12px;
    }
    .PD-container .modal-body .container{
        margin: 0 !important;
        padding: 0 !important;
        justify-self: center;
    }
    
    .flip-book .view .prev, .flip-book .view .next{
        display: none;
        visibility: hidden;
    }

}

.content-wrapper .opened-book .book {

    width: 12rem;

    height: 8rem;



}



.modal .opened-book .book {

    width: 1080px;

    height: 622px;

    margin: 6em auto 0 auto;



}



.opened-book .page {

    flex: 1;

    padding: unset !important;

    background: #fff;

    font-size: 0.65em;

    line-height: 1.2em;

    color: #222;

    position: relative;

    overflow: hidden;

    z-index: 1;

}



.opened-book .page img {

    width: 110%;

}



.opened-book .page:first-child {

    border-right: 1px solid rgba(0, 0, 0, 0.2);

    background: #fff linear-gradient(90deg, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0) 3%);

}



.opened-book .page:last-child {

    background: #fff linear-gradient(90deg, rgba(0, 0, 0, 0) 97%, rgba(0, 0, 0, 0.1) 100%);

}



.opened-book .page h2 {

    margin: 0 0 0.6em 0;

    font-family: 'UnifrakturCook', cursive;

    font-size: 1.45em;

    line-height: 1em;

    text-align: center;

}



.opened-book .page h2+p:first-letter {

    font-family: 'UnifrakturCook', cursive;

    font-size: 2.2em;

    line-height: 0.6em;

    color: #333;

    padding: 5px 2px 0 0;

    float: left;

}



.opened-book .page p {

    text-align: justify;

    margin: 0 0 0.5em;

}



.book-image-wrapper-section {

    overflow: hidden;

    height: fit-content;

    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);

    border-radius: 16px;

    position: relative;

}

.PD-container .modal-body {

    height: 100vh;

}



.flipbook-holder {

    width: 90vw;

    height: 100vh;

    justify-self: center;

    position: relative;

    max-width: 1060px;

    max-height: 670px;

}



.flipbook {

    width: 100% !important;

    height: 100% !important;



}



.shadow {

    display: none;

}



.flipbook .hard {

    background: #fff !important;

    color: #fff;

    font-weight: bold;

    border: none;

    width: 100% !important;

    height: fit-content !important;

}



.flipbook .hard small {

    font-style: italic;

    font-weight: lighter;

    opacity: 0.7;

    font-size: 14px;

}



.page-wrapper {

    width: 50% !important;

    height: 100% !important;

}



.page-wrapper>* {

    width: 100% !important;

    height: 100% !important;

}



.flipbook .page {

    background: white;

    display: flex;

    flex-direction: column;

    justify-content: center;

    align-items: center;

    gap: 10px;

    border: 1px solid rgba(0, 0, 0, 0.11);

    width: 100% !important;

    height: fit-content !important;

    height: 100% !important;



}



.flipbook .page object {

    width: 100%;

    object-fit: cover;



}



.flipbook .page small {

    font-size: 14px;

    margin-bottom: 10px;

}



.flipbook-holder button {

    position: absolute;

    z-index: 100;

    height: 100%;

    background: unset;

    border: unset;

}



.flipbook-holder button i {

    cursor: pointer;

    padding: 10px;

    background: white;

    border-radius: 10px;

}



.flipbook-holder button#prevBtn {

    left: -20px;

}

.flipbook-holder button#nextBtn {

    right: -20px;

}



@media (max-width: 1170px) {

    .flipbook-holder {

        max-width: 740px;

        max-height: 467px;

    }

    .flipbook-holder button {

        display: flex !important;

        bottom: -60px;



    }

    .flipbook-holder button#prevBtn {

        left: -20px;

        width: 50%;

        height: unset;

        justify-content: end;

    }

    .flipbook-holder button#nextBtn {

        right: -20px;

        width: 50%;

        height: unset;

        justify-content: start;

    }

    .flipbook-holder {

        width: 100vw;

    }

}



@media (max-width: 1090px) {

    .modal .opened-book .book {

        width: 750px;

        height: 622px;

        margin: 6em auto 0 auto;



    }

}



@media (max-width: 767px) {

    .flipbook-holder {

        max-width: 498px;

        max-height: 315px;

    }

    .modal .opened-book .book {

        width: 460px;

        height: 622px;

        margin: 6em auto 0 auto;



    }



}



@media (max-width: 470px) {

    .flipbook-holder {

        max-width: 365px;

        max-height: 235px;

    }

    .flipbook-holder button {



        bottom: -90px;



    }

    .modal .opened-book .book {

        width: 314px;

        height: 622px;

        margin: 0;



    }



}



.PD-container .modal-body .container {

    height: 95vh;

    width: 95%;

    margin: 20px auto;

    padding: 40px;

}

.PD-container .modal-body .fullscreen {

    background-color: #333;

}

.PD-container .modal-body .examples {

    position: relative;

}

.PD-container .modal-body .examples div {

    position: absolute;

    text-align: center;

    width: 100%;

    padding-top: 10px;

    font-size: 20px;

}

.PD-container .modal-body .examples a {

    color: #ccc;

    text-decoration: none;

    padding: 0 10px;

}

.PD-container .modal-body .examples a:hover {

    color: #fff;

}

.PD-container .modal-body .demo-msg {

    display: none !important;

}