body.dal-review-modal-open,
body.dal-modal-open {
    overflow: hidden;
}

.dal-review-overlay[hidden],
.dal-review-modal[hidden] {
    display: none !important;
}

.dal-review-overlay {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    z-index: 99998;
    background: rgba(0, 0, 0, .5);
    opacity: 0;
    transition: opacity .18s ease;
}

.dal-review-modal {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    z-index: 99999;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 48px 24px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease;
}

.dal-review-modal.is-open,
.dal-review-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}

.dal-review-modal__panel {
    position: relative;
    width: min(860px, calc(100vw - 48px));
    max-height: calc(100vh - 96px);
    overflow-y: auto;
    overscroll-behavior: contain;
    background: #fff;
    border-radius: 18px;
    padding: 36px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, .28);
    scrollbar-width: none;
    -ms-overflow-style: none;
    transform: translateY(14px);
    transition: transform .18s ease;
}

.dal-review-modal__panel::-webkit-scrollbar {
    display: none;
}

.dal-review-list-modal .dal-review-modal__panel {
    width: min(920px, calc(100vw - 48px));
}

.dal-review-modal.is-open .dal-review-modal__panel {
    transform: translateY(0);
}

.dal-review-modal__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 50%;
    background: #f2f5f8;
    color: #071f3c;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.dal-review-modal__close:hover,
.dal-review-modal__close:focus {
    background: #071f3c;
    color: #fff;
}

.dal-review-modal__header {
    margin: 0 0 26px;
    text-align: center;
}

.dal-review-modal__header h2 {
    margin: 0 0 8px;
    color: #071f3c;
    font-size: 32px;
    font-weight: 800;
    letter-spacing: 0;
}

.dal-review-modal__header p {
    margin: 0 0 18px;
    color: #5d6b7a;
    font-size: 15px;
}

.dal-review-product {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    max-width: 100%;
    padding: 10px 14px;
    border: 1px solid #e4ebf3;
    border-radius: 14px;
    text-align: left;
}

.dal-review-product img {
    width: 56px;
    height: 56px;
    object-fit: contain;
    border-radius: 10px;
    background: #f6f8fb;
}

.dal-review-product strong {
    color: #071f3c;
    font-size: 14px;
}

.dal-review-form .fieldset {
    margin: 0;
    padding: 0;
    border: 0;
}

.dal-review-section {
    padding: 24px 0;
    border-top: 1px solid #e7edf5;
}

.dal-review-section legend,
.dal-review-section > .label,
.dal-review-form .field > .label,
.dal-review-details .field > span {
    display: block;
    margin: 0 0 10px;
    color: #071f3c;
    font-size: 15px;
    font-weight: 800;
}

.dal-review-form .required > .label span:after,
.dal-review-rating > legend span:after,
.dal-review-consent.required span:after {
    content: ' *';
    color: #d02f2f;
}

.dal-review-rating-name {
    display: none;
}

.dal-review-form .review-control-vote {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    gap: 8px;
    height: auto;
    margin: 4px 0 0;
}

.dal-review-form .review-control-vote:before,
.dal-review-form .review-control-vote label:before {
    display: none !important;
}

.dal-review-form .review-control-vote input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.dal-review-form .review-control-vote label {
    width: 42px;
    height: 42px;
    margin: 0;
    color: #c9d3df;
    font-size: 0;
    cursor: pointer;
}

.dal-review-form .review-control-vote label:after {
    content: '★';
    font-size: 38px;
    line-height: 42px;
}

.dal-review-form .review-control-vote input:checked ~ label,
.dal-review-form .review-control-vote label:hover,
.dal-review-form .review-control-vote label:hover ~ label {
    color: #1473e6;
}

.dal-review-form input[type='text'],
.dal-review-form input[type='email'],
.dal-review-form textarea,
.dal-review-form select {
    width: 100%;
    min-height: 48px;
    border: 1px solid #ccd8e6;
    border-radius: 10px;
    padding: 12px 14px;
    background: #fff;
    color: #071f3c;
    font-size: 15px;
    box-shadow: none;
}

.dal-review-form textarea {
    min-height: 140px;
    resize: vertical;
}

.dal-review-form .field {
    margin: 0 0 18px;
}

.dal-review-form .note,
.dal-review-section > p {
    margin: 8px 0 0;
    color: #667789;
    font-size: 13px;
    line-height: 1.6;
}

.dal-review-radio-group {
    margin: 0 0 22px;
}

.dal-review-radio-group p {
    margin: 0 0 10px;
    color: #071f3c;
    font-weight: 800;
}

.dal-review-radio-group label {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 42px;
    color: #253a52;
}

.dal-review-radio-group input[type='radio'] {
    width: 22px;
    height: 22px;
    accent-color: #1473e6;
}

.dal-review-upload-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 108px;
    height: 108px;
    margin-top: 14px;
    border: 1px dashed #b8c8dc;
    border-radius: 16px;
    background: #f8fbff;
    color: #6a7c90;
}

.dal-review-upload-placeholder span {
    font-size: 36px;
    line-height: 1;
}

.dal-review-upload-placeholder small {
    margin-top: 8px;
    padding: 0 8px;
    text-align: center;
    font-size: 11px;
    line-height: 1.25;
}

.dal-review-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.dal-review-grid .review-field-nickname {
    grid-column: 1 / -1;
}

.dal-review-consent {
    padding: 20px 0 24px;
    border-top: 1px solid #e7edf5;
}

.dal-review-consent label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: #42556a;
    font-size: 13px;
    line-height: 1.6;
}

.dal-review-consent input {
    flex: 0 0 auto;
    margin-top: 4px;
    accent-color: #1473e6;
}

.dal-review-form-actions .primary,
.dal-review-form-actions .actions-primary,
.dal-review-form-actions .action.submit {
    width: 100%;
}

.dal-review-form-actions .action.submit {
    min-height: 54px;
    border: 0;
    border-radius: 999px;
    background: #071f3c;
    color: #fff;
    font-size: 15px;
    font-weight: 800;
    text-transform: uppercase;
}

.dal-review-form-actions .action.submit:hover,
.dal-review-form-actions .action.submit:focus {
    background: #1473e6;
}

.dal-review-form .mage-error {
    margin-top: 6px;
    color: #d02f2f;
    font-size: 12px;
}

.dal-review-login {
    margin: 24px 0;
}

.dal-review-form-host #product-review-container {
    display: none;
}

.dal-review-section-panel {
    display: grid;
    gap: 0;
}

.dal-review-summary-card {
    display: grid;
    gap: 18px;
    padding: 22px 24px;
    border: 1px solid #e5eaf2;
    border-radius: 16px;
    background: #ffffff;
}

.dal-review-summary-header h3 {
    margin: 0 0 10px;
    color: #071f3c;
    font-size: 20px;
    font-weight: 800;
}

.dal-review-rating {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.dal-review-score,
.dal-review-rating {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 5px;
}

.dal-review-score.is-centered {
    justify-content: center;
}

.dal-review-score strong {
    color: #071f3c;
    font-size: 22px;
    line-height: 1;
}

.dal-review-score-text {
    color: #071f3c;
    font-size: 18px;
    font-weight: 800;
}

.dal-review-count {
    color: #667789;
    font-size: 13px;
}

.dal-review-stars {
    display: inline-flex;
    gap: 2px;
    color: #c8d1dc;
    font-size: 15px;
    line-height: 1;
}

.dal-review-stars .is-filled {
    color: #f4b400;
}

.dal-review-actions,
.dal-review-modal-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 2px;
}

.dal-review-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 150px;
    min-height: 42px;
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
}

.dal-review-button.is-primary {
    border: 1px solid #006cff;
    background: #006cff;
    color: #ffffff;
}

.dal-review-button.is-secondary {
    border: 1px solid #d8e0ec;
    background: #ffffff;
    color: #071b3a;
}

.dal-review-button:hover,
.dal-review-button:focus {
    border-color: #071f3c;
    background: #071f3c;
    color: #ffffff;
    text-decoration: none;
}

.dal-review-card-list {
    display: grid;
    gap: 14px;
}

.dal-review-card-list.is-modal {
    max-width: 820px;
    margin: 0 auto;
}

.dal-review-card {
    padding: 18px;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: #ffffff;
}

.dal-review-card__top {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.dal-review-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #edf4ff;
    color: #1473e6;
    font-weight: 900;
}

.dal-review-card__meta strong {
    display: block;
    color: #071f3c;
    font-size: 14px;
}

.dal-review-card__rating {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 5px;
    color: #667789;
    font-size: 12px;
}

.dal-review-date {
    color: #7a8796;
    font-size: 12px;
    white-space: nowrap;
}

.dal-review-card__title {
    margin: 14px 0 8px;
    color: #071f3c;
    font-size: 15px;
    font-weight: 800;
}

.dal-review-card__content {
    color: #33465c;
    font-size: 14px;
    line-height: 1.65;
}

.dal-review-images {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.dal-review-images img {
    width: 82px;
    height: 82px;
    object-fit: cover;
    border-radius: 8px;
    background: #f4f6f8;
}

.dal-review-empty {
    padding: 18px;
    border: 1px dashed #cbd5e1;
    border-radius: 12px;
    background: #f8fbff;
    color: #42556a;
}

.dal-review-preview {
    display: grid;
    gap: 12px;
}

.dal-review-empty-text {
    margin: 0;
    color: #42556a;
    line-height: 1.6;
}

.dal-review-empty p {
    margin: 0 0 14px;
}

.dal-review-photo-note {
    margin: 0;
    color: #667789;
    font-size: 13px;
}

.dal-review-list-product {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    max-width: 100%;
    margin: 0 auto 14px;
    padding: 8px 12px;
    border: 1px solid #e4ebf3;
    border-radius: 14px;
    text-align: left;
}

.dal-review-list-product img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    border-radius: 10px;
    background: #f6f8fb;
}

.dal-review-list-product strong {
    color: #071f3c;
    font-size: 14px;
}

.dal-review-modal-actions {
    justify-content: center;
    margin-top: 22px;
}

.dalactive-photo-review-upload {
    margin-top: 14px;
}

.dalactive-photo-review-upload input[type='file'] {
    width: 100%;
    min-height: 48px;
    padding: 10px;
    border: 1px dashed #b8c8dc;
    border-radius: 12px;
    background: #f8fbff;
}

@media (max-width: 767px) {
    .dal-review-modal {
        padding: 16px 12px;
        align-items: stretch;
    }

    .dal-review-modal__panel {
        width: calc(100vw - 24px);
        max-width: none;
        max-height: calc(100dvh - 32px);
        border-radius: 14px;
        padding: 20px;
    }

    .dal-review-modal__header h2 {
        font-size: 26px;
    }

    .dal-review-product {
        width: 100%;
    }

    .dal-review-form .review-control-vote label {
        width: 34px;
        height: 38px;
    }

    .dal-review-form .review-control-vote label:after {
        font-size: 32px;
        line-height: 38px;
    }

    .dal-review-grid {
        grid-template-columns: 1fr;
    }

    .dal-review-actions,
    .dal-review-modal-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .dal-review-button {
        width: 100%;
    }

    .dal-review-card__top {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .dal-review-date {
        grid-column: 2;
        white-space: normal;
    }
}

/* DAL Active review compact actions: equal inline buttons on product detail. */
.dal-review-summary-card .dal-review-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 12px;
    max-width: 440px;
}

.dal-review-summary-card .dal-review-button {
    width: 100%;
    min-width: 0;
    min-height: 48px;
    padding: 11px 16px;
}

.dal-review-form .review-field-ratings .label {
    margin-bottom: 12px;
}

.dal-review-form .review-field-ratings .label span:before {
    content: 'Chọn số sao - ';
}

@media (max-width: 520px) {
    .dal-review-summary-card .dal-review-actions {
        grid-template-columns: 1fr;
        max-width: none;
    }
}

/* Final PDP review card override: full card visible and equal action buttons. */
.catalog-product-view .dal-review-section-panel,
.catalog-product-view .dal-review-summary-card,
.catalog-product-view .dal-review-preview,
.catalog-product-view .dal-review-actions {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

.catalog-product-view .dal-review-summary-card {
    box-sizing: border-box !important;
    width: 100% !important;
    padding: 28px 28px 30px !important;
}

.catalog-product-view .dal-review-summary-card .dal-review-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
    max-width: 470px !important;
    margin-top: 28px !important;
}

.catalog-product-view .dal-review-summary-card .dal-review-button {
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 56px !important;
    min-height: 56px !important;
    padding: 0 18px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
}

@media (max-width: 520px) {
    .catalog-product-view .dal-review-summary-card .dal-review-actions {
        grid-template-columns: 1fr !important;
        max-width: none !important;
    }
}



/* Final simple write-review modal: stars + review text only. */
.dal-review-form .dal-review-ui-only,
.dal-review-form .dal-review-photo-section,
.dal-review-form .dal-review-details,
.dal-review-form .dal-review-consent,
.dal-review-form .review-field-nickname {
    display: none !important;
}

.dal-review-form .additional_info:empty {
    display: none !important;
}

.dal-review-form .dal-review-section {
    padding: 22px 0 !important;
}

.dal-review-form .review-field-ratings {
    text-align: center;
}

.dal-review-form .review-field-ratings .label {
    display: block;
    margin-bottom: 12px;
    text-align: center;
}

.dal-review-form .review-control-vote {
    justify-content: center !important;
    margin-top: 8px !important;
}

.dal-review-form .review-control-vote label {
    transition: color .15s ease, transform .15s ease;
}

.dal-review-form .review-control-vote label:hover,
.dal-review-form .review-control-vote label:hover ~ label,
.dal-review-form .review-control-vote label.is-selected,
.dal-review-form .review-control-vote input:checked ~ label {
    color: #f5b301 !important;
}

.dal-review-form .review-control-vote label:hover {
    transform: translateY(-1px);
}

.dal-review-rating-status {
    margin: 12px 0 0;
    color: #071f3c;
    font-size: 14px;
    font-weight: 700;
    text-align: center;
}

.dal-review-form .review-field-text {
    margin-bottom: 0 !important;
}

.dal-review-form .review-field-text textarea {
    min-height: 160px !important;
    font-size: 16px !important;
    line-height: 1.55 !important;
}

.dal-review-form .review-form-actions {
    margin-top: 12px;
}


/* Final correction: title is required and visible; only nickname is hidden. */
.dal-review-form .review-field-summary {
    display: block !important;
    margin-top: 18px !important;
}

.dal-review-form .review-field-summary .label {
    display: block !important;
}

.dal-review-form .review-field-summary input {
    display: block !important;
}

.dal-review-form .review-control-vote label.is-selected:after,
.dal-review-form .review-control-vote label:hover:after,
.dal-review-form .review-control-vote label:hover ~ label:after {
    color: #f5b301 !important;
}

/* Final rating reset: Magento's base rating mixin absolutely positions labels.
   Keep the native radio values, but render a clean 5-star selector. */
.dal-review-form .review-field-ratings.required > .label span:after,
.dal-review-form .dal-review-rating > legend span:after {
    content: none !important;
}

.dal-review-form .review-field-ratings > legend.label span:after {
    content: ' *' !important;
    color: #d02f2f !important;
}

.dal-review-form .review-field-ratings .label span:before {
    content: none !important;
    display: none !important;
}

.dal-review-form .review-field-rating,
.dal-review-form #product-review-table,
.dal-review-form #product-review-table .nested,
.dal-review-form .review-field-ratings .control {
    overflow: visible !important;
}

.dal-review-form .review-control-vote {
    align-items: center !important;
    display: flex !important;
    flex-direction: row !important;
    gap: 8px !important;
    height: 48px !important;
    justify-content: center !important;
    margin: 12px auto 0 !important;
    overflow: visible !important;
    position: relative !important;
    width: auto !important;
}

.dal-review-form .review-control-vote:before,
.dal-review-form .review-control-vote:after {
    content: none !important;
    display: none !important;
}

.dal-review-form .review-control-vote input[type='radio'] {
    height: 1px !important;
    left: -9999px !important;
    opacity: 0 !important;
    pointer-events: none !important;
    position: absolute !important;
    top: auto !important;
    width: 1px !important;
}

.dal-review-form .review-control-vote label,
.dal-review-form .review-control-vote label.rating-1,
.dal-review-form .review-control-vote label.rating-2,
.dal-review-form .review-control-vote label.rating-3,
.dal-review-form .review-control-vote label.rating-4,
.dal-review-form .review-control-vote label.rating-5 {
    align-items: center !important;
    color: #c9d3df !important;
    cursor: pointer !important;
    display: inline-flex !important;
    float: none !important;
    font-size: 0 !important;
    height: 42px !important;
    justify-content: center !important;
    left: auto !important;
    line-height: 1 !important;
    margin: 0 !important;
    overflow: visible !important;
    position: static !important;
    text-indent: 0 !important;
    top: auto !important;
    transform: none !important;
    width: 42px !important;
}

.dal-review-form .review-control-vote label:before {
    content: none !important;
    display: none !important;
}

.dal-review-form .review-control-vote label:after {
    color: currentColor !important;
    content: '★' !important;
    display: block !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: 38px !important;
    height: 42px !important;
    line-height: 42px !important;
    position: static !important;
    width: 42px !important;
}

.dal-review-form .review-control-vote label.is-selected,
.dal-review-form .review-control-vote label.is-selected:after,
.dal-review-form .review-control-vote label:hover,
.dal-review-form .review-control-vote label:hover:after {
    color: #f5b301 !important;
}

.dal-review-form .review-control-vote:hover label {
    color: #c9d3df !important;
}

.dal-review-form .review-control-vote label:hover,
.dal-review-form .review-control-vote label:hover ~ label {
    color: #f5b301 !important;
}

/* JS-driven star state. This prevents Magento's native sibling selector from
   painting the wrong stars after we reset the rating labels to normal flex. */
.dal-review-form .review-control-vote input:checked ~ label,
.dal-review-form .review-control-vote label:hover,
.dal-review-form .review-control-vote label:hover ~ label {
    color: #c9d3df !important;
}

.dal-review-form .review-control-vote label.is-selected,
.dal-review-form .review-control-vote label.is-selected:after,
.dal-review-form .review-control-vote label.is-hovered,
.dal-review-form .review-control-vote label.is-hovered:after {
    color: #f5b301 !important;
}
