.oliveyoung-page {
        min-height: calc(100vh - 150px);
        background: #fff;
        padding: 28px 20px 36px;
    }

    .oliveyoung-content {
        width: 100%;
        max-width: 760px;
        margin: 0 auto;
    }

    .oliveyoung-panel {
        width: 100%;
        border: 1px solid #e4e8df;
        border-radius: 8px;
        padding: 24px 18px;
        background: #fff;
    }

    .oliveyoung-brand {
        color: #5f8f1f;
        font-size: 14px;
        font-weight: 700;
        text-transform: uppercase;
        margin-bottom: 4px;
    }

    .oliveyoung-title {
        color: #222;
        font-size: 22px;
        line-height: 28px;
        font-weight: 700;
        margin-bottom: 8px;
    }

    .oliveyoung-desc {
        color: #666;
        font-size: 14px;
        line-height: 20px;
        margin-bottom: 14px;
    }

    .traveloka-provider {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        border: 1px solid #dbe9f5;
        border-radius: 8px;
        background: #f7fbff;
        padding: 12px 14px;
        margin-bottom: 22px;
    }

    .traveloka-provider-label {
        color: #32465a;
        font-size: 14px;
        line-height: 20px;
        font-weight: 700;
    }

    .traveloka-provider img {
        display: block;
        width: 132px;
        max-width: 44%;
        height: auto;
    }

    .voucher-label {
        display: block;
        color: #333;
        font-size: 16px;
        font-weight: 500;
        margin-bottom: 10px;
    }

    .voucher-inputs {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 8px;
        margin-bottom: 16px;
    }

    .voucher-part {
        width: 100%;
        height: 48px;
        border: 1px solid #d7ddcf;
        border-radius: 6px;
        color: #222;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0;
        text-align: center;
        text-transform: uppercase;
        outline: none;
        background: #fbfcf8;
    }

    .voucher-part:focus {
        border-color: #7aad2b;
        background: #fff;
        box-shadow: 0 0 0 3px rgba(122, 173, 43, 0.14);
    }

    .voucher-hint {
        min-height: 20px;
        color: #777;
        font-size: 13px;
        line-height: 20px;
        margin-bottom: 18px;
    }

    .voucher-submit {
        width: 100%;
        height: 46px;
        border: 0;
        border-radius: 6px;
        background: #6aa322;
        color: #fff;
        cursor: pointer;
        font-size: 16px;
        font-weight: 700;
    }

    .voucher-submit:disabled {
        background: #c9d6bb;
        cursor: default;
    }

    .voucher-reset {
        width: 100%;
        height: 42px;
        border: 1px solid #b7c9a3;
        border-radius: 6px;
        background: #fff;
        color: #3f6411;
        cursor: pointer;
        font-size: 14px;
        font-weight: 700;
        margin-top: 10px;
    }

    .voucher-inline-result {
        display: none;
        border: 1px solid #dce8ce;
        border-radius: 8px;
        background: #fbfcf8;
        padding: 16px;
        margin-top: 18px;
    }

    .oliveyoung-info {
        margin-top: 28px;
        color: #333;
    }

    .oliveyoung-section {
        border-top: 1px solid #e7eadf;
        padding-top: 22px;
        margin-top: 22px;
    }

    .oliveyoung-section:first-child {
        border-top: 0;
        padding-top: 0;
        margin-top: 0;
    }

    .oliveyoung-section-title {
        color: #263915;
        font-size: 18px;
        line-height: 24px;
        font-weight: 700;
        margin: 0 0 12px;
    }

    .oliveyoung-text {
        color: #555;
        font-size: 14px;
        line-height: 22px;
        margin: 0 0 10px;
    }

    .oliveyoung-list {
        margin: 0;
        padding-left: 20px;
        color: #555;
        font-size: 14px;
        line-height: 22px;
    }

    .oliveyoung-list li {
        margin-bottom: 8px;
    }

    .oliveyoung-steps {
        margin: 0;
        padding-left: 20px;
        color: #555;
        font-size: 14px;
        line-height: 22px;
    }

    .oliveyoung-steps li {
        margin-bottom: 8px;
    }

    .oliveyoung-note-title {
        color: #333;
        font-size: 14px;
        font-weight: 700;
        line-height: 22px;
        margin: 14px 0 8px;
    }

    .oliveyoung-modal .modal-dialog {
        max-width: 640px;
    }

    .oliveyoung-modal .modal-content {
        border: 0;
        border-radius: 8px;
        overflow: hidden;
    }

    .oliveyoung-modal .modal-header {
        align-items: center;
        padding: 18px 20px;
    }

    .oliveyoung-modal .modal-header:before,
    .oliveyoung-modal .modal-footer:before {
        display: none;
    }

    .oliveyoung-modal .modal-title {
        color: #263915;
        font-size: 18px;
        line-height: 24px;
        text-align: left;
        text-transform: none;
    }

    .oliveyoung-modal .modal-body {
        padding: 18px 20px;
    }

    .voucher-status {
        display: inline-block;
        border-radius: 6px;
        padding: 7px 10px;
        font-size: 14px;
        font-weight: 700;
        line-height: 18px;
        margin-bottom: 12px;
    }

    .voucher-status-valid,
    .voucher-status-success {
        color: #3f6411;
        background: #edf6e1;
    }

    .oliveyoung-modal-text {
        color: #555;
        font-size: 14px;
        line-height: 22px;
        margin: 0 0 14px;
    }

    .oliveyoung-save-note {
        border: 1px solid #dce8ce;
        border-radius: 6px;
        background: #f6fbef;
        color: #3f6411;
        font-size: 14px;
        font-weight: 700;
        line-height: 20px;
        margin: 0 0 14px;
        padding: 10px 12px;
    }

    .oliveyoung-message-modal .modal-dialog {
        max-width: 440px;
    }

    .oliveyoung-message-modal .modal-body {
        padding: 22px 24px 8px;
        text-align: center;
    }

    .oliveyoung-message-icon {
        align-items: center;
        background: #fff4e5;
        border: 1px solid #ffd39a;
        border-radius: 50%;
        color: #b56300;
        display: inline-flex;
        font-size: 22px;
        font-weight: 800;
        height: 48px;
        justify-content: center;
        line-height: 1;
        margin-bottom: 14px;
        width: 48px;
    }

    .oliveyoung-message-text {
        color: #333;
        font-size: 15px;
        font-weight: 500;
        line-height: 22px;
        margin: 0;
        word-break: break-word;
    }

    .oliveyoung-modal-subtitle {
        color: #263915;
        font-size: 15px;
        line-height: 22px;
        font-weight: 700;
        margin: 18px 0 10px;
    }

    .oliveyoung-modal-list {
        margin: 0;
        padding-left: 20px;
        color: #555;
        font-size: 14px;
        line-height: 22px;
    }

    .oliveyoung-modal-list li {
        margin-bottom: 8px;
    }

    .voucher-detail-row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 14px;
        border: 1px solid #e2e8d9;
        border-radius: 6px;
        padding: 12px;
        color: #555;
        font-size: 14px;
        line-height: 20px;
        margin-bottom: 10px;
        background: #fbfcf8;
    }

    .voucher-detail-row strong {
        color: #222;
        text-align: right;
        word-break: break-word;
    }

    .voucher-detail-link {
        display: block;
    }

    .voucher-detail-link span {
        display: block;
        margin-bottom: 6px;
    }

    .voucher-link-heading {
        align-items: center;
        display: flex;
        gap: 10px;
        justify-content: space-between;
        margin-bottom: 6px;
    }

    .voucher-link-heading span {
        margin-bottom: 0;
    }

    .voucher-copy-link {
        border: 1px solid #b7c9a3;
        border-radius: 6px;
        background: #fff;
        color: #3f6411;
        cursor: pointer;
        flex: 0 0 auto;
        font-size: 13px;
        font-weight: 700;
        min-height: 30px;
        padding: 0px 18px;
        height: 42px;
    }

    .voucher-action-copy {
        display: block;
        margin-top: 6px;
        min-width: 108px;
        width: 100%;
    }

    .voucher-detail-link a {
        display: block;
        color: #2d741f;
        font-weight: 700;
        word-break: break-all;
    }

    .voucher-result-card {
        margin-top: 14px;
    }

    .voucher-inline-capture {
        margin-top: 6px;
    }

    .oliveyoung-modal-footer {
        flex-wrap: wrap;
        gap: 10px;
        padding: 16px 20px 20px;
    }

    .oliveyoung-modal-footer .voucher-action-copy {
        flex: 0 0 100%;
        margin-top: 0;
    }

    .oliveyoung-modal-button {
        min-width: 108px;
        height: 42px;
        border-radius: 6px;
        border: 1px solid transparent;
        cursor: pointer;
        font-size: 14px;
        font-weight: 700;
        padding: 0 18px;
    }

    .oliveyoung-modal-button-primary {
        color: #fff;
        background: #6aa322;
        border-color: #6aa322;
    }

    .oliveyoung-modal-button:disabled {
        cursor: default;
        opacity: 0.65;
    }

    .oliveyoung-modal-button-secondary {
        color: #3f6411;
        background: #fff;
        border-color: #b7c9a3;
    }

    @media (min-width: 768px) {
        .oliveyoung-page {
            padding: 36px 24px 48px;
        }

        .oliveyoung-panel {
            padding: 30px;
        }
    }

    @media (max-width: 575px) {
        .traveloka-provider {
            align-items: flex-start;
            display: grid;
            grid-template-columns: 1fr;
        }

        .traveloka-provider img {
            max-width: 100%;
        }

        .oliveyoung-modal-footer {
            display: grid;
            grid-template-columns: 1fr;
        }

        .oliveyoung-modal-button {
            width: 100%;
        }

        .voucher-detail-row {
            display: block;
        }

        .voucher-detail-row strong {
            display: block;
            margin-top: 6px;
            text-align: left;
        }

        .voucher-link-heading {
            align-items: flex-start;
            display: grid;
            grid-template-columns: 1fr;
        }
    }
