.sgp-btn {
    background-color: #f47f00;
    color: #fff;
    border: none;
    border-radius: 3px;
    padding: 2px 7px;
    font-size: 11px;
    font-weight: bold;
    cursor: pointer;
    margin-left: 6px;
    margin-right: 4px;
    vertical-align: middle;
    line-height: 18px;
}

.sgp-btn:hover {
    background-color: #d96e00;
}

.sgp-btn.active {
    background-color: #a85500;
}

.sgp-iframe-cell {
    padding: 0 !important;
    position: relative;
}

.sgp-iframe-cell iframe {
    display: block;
    border: none;
    width: 100%;
}

.sgp-loading {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.12);
    z-index: 1;
}

.sgp-loading::after {
    content: '';
    width: 36px;
    height: 36px;
    border: 4px solid rgba(255, 255, 255, 0.25);
    border-top-color: #f47f00;
    border-radius: 50%;
    animation: sgp-spin 0.7s linear infinite;
}

@keyframes sgp-spin {
    to { transform: rotate(360deg); }
}

.rr-multi-panel { padding: 8px 12px; border-bottom: 1px solid #eee; }
.rr-amount-mode { margin-bottom: 8px; }
.rr-amount-mode label { display: inline-flex; align-items: center; gap: 6px; margin-right: 16px; font-weight: normal; cursor: pointer; line-height: 1; }
.rr-amount-mode label input[type="radio"] { margin: 0; vertical-align: middle; }
.rr-options .rr-option-row {
    display: flex; align-items: center; gap: 8px;
    padding: 4px 8px; border-radius: 3px;
}
.rr-options .rr-option-row label {
    display: flex; align-items: center; gap: 6px;
    margin: 0; font-weight: bold; cursor: pointer; line-height: 1;
    white-space: nowrap; flex-shrink: 0;
}
.rr-options .rr-option-row label input[type="checkbox"] { margin: 0; vertical-align: middle; }
.rr-options .rr-option-row.rr-selected { background-color: #f0f6ff; }
.rr-amt-per-row { width: 100px; flex-shrink: 0; }
.submit-bet + .ticket-number { word-break: break-all; }