/* ==========================================================================
   SINGLE PANEL VIEW (FRONTEND)
   ==========================================================================
   This stylesheet contains all the custom styles for the single panel view 
   on the frontend. All selectors are strictly scoped under the main wrapper 
   ID (#cbp-spv-wrapper) to prevent style conflicts with the active theme.
   ========================================================================== */

/* Main Wrapper Settings */
#cbp-spv-wrapper {
    font-family: var(--cbp-font-family) !important;
    color: var(--cbp-text-main) !important;
    max-width: 768px !important;
    margin: 0 auto !important;
    padding: 0rem !important;
    box-sizing: border-box !important;
    background-color: var(--cbp-bg-body) !important;
}

/* Ensure all child elements respect box-sizing */
#cbp-spv-wrapper * {
    box-sizing: border-box !important;
}

/* Main inner container utilizing flex base layout */
#cbp-spv-wrapper .cbp-spv-main {
    display: flex !important;
    flex-direction: column !important;
    gap: 2rem 0rem !important;
}

/* ==========================================================================
   1. HEADER SECTION
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-header {
    background-color: var(--cbp-bg-darker) !important;
    padding: 1rem !important;
    border-radius: 2rem !important;
    border: 1px solid var(--cbp-border-medium) !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    min-height: 80px !important;
}

/* Left side of the header containing logo and titles */
#cbp-spv-wrapper .cbp-spv-header-left {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

/* Panel Logo/Image container */
#cbp-spv-wrapper .cbp-spv-p-img {
    width: 60px !important;
    height: auto !important;
    background-color: var(--cbp-fallback-img-bg) !important;
    border-radius: 100rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    color: #fff !important;
    font-weight: bold !important;
    font-size: 1.2rem !important;
    border: 1px solid var(--cbp-primary) !important;
}

#cbp-spv-wrapper .cbp-spv-p-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* Panel Info Container (Title and Link) */
#cbp-spv-wrapper .cbp-spv-p-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    align-items: flex-start !important;
}

/* Panel Title */
#cbp-spv-wrapper .cbp-spv-p-title {
    margin: 0 !important;
    font-size: 1.3rem !important;
    font-weight: 600 !important;
    color: var(--cbp-text-main) !important;
    line-height: 1.25 !important;
}

/* External Link under the title */
#cbp-spv-wrapper .cbp-spv-p-link a {
    font-size: 1.1rem !important;
    text-decoration: underline !important;
    text-transform: capitalize !important;
    color: var(--cbp-text-muted) !important;
    font-weight: 500 !important;
}

/* Icon Link (e.g., info or external icon) */
#cbp-spv-wrapper .cbp-spv-header-icon-link {
    color: var(--cbp-text-muted) !important;
    padding: 0.5rem !important;
    text-decoration: none !important;
}

#cbp-spv-wrapper .cbp-spv-link-icon {
    font-size: 2rem !important;
    color: var(--cbp-primary) !important;
}

#cbp-spv-wrapper .cbp-spv-link-icon:hover {
    color: var(--cbp-primary) !important;
}

/* ==========================================================================
   2. PLAN TYPE TOGGLE (Sharing / Non-Refundable)
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-plan-toggle {
    display: flex !important;
    background-color: var(--cbp-primary-transparent) !important;
    padding: 0.25rem !important;
    border-radius: 9999px !important;
    border: 1px solid var(--cbp-border-light) !important;
}


/* Individual toggle buttons */
#cbp-spv-wrapper .cbp-spv-radio-btn,
#cbp-spv-wrapper .cbp-spv-nr-btn {
    flex: 1 !important;
    padding: 0.75rem 1rem !important;
    border-radius: 9999px !important;
    border: none !important;
    font-size: 1.2rem !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.cbp-spv-radio-btn span {
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}

/* Active state of toggle buttons */
#cbp-spv-wrapper .cbp-spv-radio-btn.active,
#cbp-spv-wrapper .cbp-spv-nr-btn.active {
    background-color: var(--cbp-primary) !important;
    color: var(--cbp-text-dark) !important;
}

/* Inactive state of toggle buttons */
#cbp-spv-wrapper .cbp-spv-radio-btn:not(.active),
#cbp-spv-wrapper .cbp-spv-nr-btn:not(.active) {
    background-color: transparent !important;
    color: var(--cbp-text-muted) !important;
}

/* ==========================================================================
   3. INPUT FIELDS SECTION (Coins & Name)
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-inputs {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

/* Input group container */
#cbp-spv-wrapper .cbp-spv-input-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
}

/* Labels above inputs */
#cbp-spv-wrapper .cbp-spv-input-group label {
    font-size: 1.1rem !important;
    font-weight: 500 !important;
    color: var(--cbp-text-main) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    margin-left: 0.25rem !important;
}

/* Input Wrapper to position items relative */
#cbp-spv-wrapper .cbp-spv-input-wrapper {
    position: relative !important;
    width: 100% !important;
}

/* Actual Input Box Styling */
#cbp-spv-wrapper .cbp-spv-input-box {
    width: 100% !important;
    height: 4.6rem !important;
    background-color: var(--cbp-bg-card) !important;
    /* border: 1px solid transparent !important; */
    border-radius: 1rem !important;
    padding: 0 1rem !important;
    color: var(--cbp-text-main) !important;
    font-family: inherit !important;
    outline: none !important;
    border: 1px solid var(--cbp-border-medium) !important;
}

#cbp-spv-wrapper .cbp-spv-input-box:focus {
    background-color: var(--cbp-primary-focus) !important;
    border: 1px solid var(--cbp-primary) !important;
}

/* Specially emphasis on input values */
#cbp-spv-wrapper .cbp-spv-bold-input {
    font-weight: 700 !important;
    font-size: 1.125rem !important;
}

/* Input Icons (like clear button, coin icon, user icon) */
#cbp-spv-wrapper .cbp-spv-icon {
    position: absolute !important;
    right: 1rem !important;
    top: 1rem !important;
    color: var(--cbp-primary) !important;
}

/* Support messages beneath input fields */
#cbp-spv-wrapper .cbp-spv-msg {
    font-size: 1rem !important;
    margin: 0 !important;
    margin-left: 0.6rem !important;
    min-height: 1rem !important;
}

#cbp-spv-wrapper .cbp-spv-msg.success {
    color: var(--cbp-status-success);
}

#cbp-spv-wrapper .cbp-spv-msg.error {
    color: var(--cbp-status-error);
}

/* Notice/warning messages for coin bounds */
#cbp-spv-wrapper .cbp-spv-coin-warning {
    color: var(--cbp-primary) !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.25rem !important;
    margin: 0 !important;
    padding: 0 0.25rem !important;
}

#cbp-spv-wrapper .cbp-spv-coin-warning span.material-symbols-outlined {
    font-size: 12px !important;
}

#cbp-spv-wrapper .cbp-spv-coin-warning.error {
    color: var(--cbp-status-error) !important;
}

/* ==========================================================================
   4. CALCULATOR CARD (Amount display)
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-calc-card {
    background-color: var(--cbp-bg-card) !important;
    border-radius: 2rem !important;
    padding: 1.5rem !important;
    border: 1px solid var(--cbp-border-light) !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
}

/* Small label identifying "Total Amount" calculation */
#cbp-spv-wrapper .cbp-spv-calc-header {
    color: var(--cbp-text-main) !important;
    font-weight: 500 !important;
    font-size: 1rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.2em !important;
    margin: 0 0 0.5rem 0 !important;
}

/* The Grand Total digits display */
#cbp-spv-wrapper .cbp-spv-calc-amount {
    font-size: 2.4rem !important;
    font-weight: 900 !important;
    color: var(--cbp-primary-hover) !important;
}

/* Word conversion for the currency */
#cbp-spv-wrapper .cbp-spv-calc-words {
   font-size: 1.1rem !important;
    color: var(--cbp-primary-hover) !important;
    opacity: 1 !important;
    font-weight: 500 !important;
    margin: 0 0 1.5rem 0 !important;
}

/* Bottom section breaking down math formula */
#cbp-spv-wrapper .cbp-spv-calc-details {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 1rem !important;
    padding-top: 1rem !important;
    border-top: 1px solid var(--cbp-border-light) !important;
}

#cbp-spv-wrapper .cbp-spv-calc-val {
    font-size: 1.4rem !important;
    font-weight: 600 !important;
    color: var(--cbp-primary-hover) !important;
    opacity: 0.9 !important;
    margin: 0 !important;
}

/* ==========================================================================
   5. RATE CHART SECTION (Expandable table)
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-rate-chart {
    background-color: var(--cbp-bg-card) !important;
    border-radius: 2rem !important;
    border: 1px solid var(--cbp-border-light) !important;
    overflow: hidden !important;
}

/* Clickable Rate Chart Header */
#cbp-spv-wrapper .cbp-spv-rate-header {
        padding: 1rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    cursor: pointer !important;
    font-size: 1.4rem !important;
    font-weight: 500 !important;
    color: var(--cbp-text-main) !important;
}

/* Rate Chart Collapsible Content */
#cbp-spv-wrapper .cbp-spv-rate-content {
    display: none !important;
    padding: 0 1rem 1rem 1rem !important;
}

#cbp-spv-wrapper .cbp-spv-rate-content.active {
    display: block !important;
}

/* Data Table settings */
#cbp-spv-wrapper .cbp-spv-table {
    width: 100% !important;
    text-align: left !important;
    border-collapse: separate !important;
    border-spacing: 0 0.5rem !important;
}

/* Caption / Title for the current view table */
#cbp-spv-wrapper .cbp-spv-table-title {
        background-color: var(--cbp-primary-hover) !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--cbp-text-dark) !important;
    border-radius: 0.7rem !important;
    padding: 0.6rem 1rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
}

/* Th styling */
#cbp-spv-wrapper .cbp-spv-table-head th {
    color: var(--cbp-text-main) !important;
    font-size: 1.2rem !important;
    font-weight: 500 !important;
    text-transform: capitalize !important;
    padding-bottom: 1rem !important;
    margin-bottom: 1rem !important;
}

/* Table body rows and columns */
#cbp-spv-wrapper .cbp-spv-tbody-tr {
    background-color: var(--cbp-bg-table-row) !important;
}

#cbp-spv-wrapper .cbp-spv-tbody-td {
    padding: 0.75rem !important;
    border-top: 1px solid var(--cbp-border-light) !important;
    border-bottom: 1px solid var(--cbp-border-light) !important;
}

/* Left edges for table border radius aesthetics */
#cbp-spv-wrapper .cbp-spv-tbody-td:first-child {
    border-left: 1px solid var(--cbp-border-light) !important;
    border-top-left-radius: 0.5rem !important;
    border-bottom-left-radius: 0.5rem !important;
}

/* Right edges and numeric column alignment for aesthetics */
#cbp-spv-wrapper .cbp-spv-tbody-td:last-child {
    border-right: 1px solid var(--cbp-border-light) !important;
    border-top-right-radius: 0.5rem !important;
    border-bottom-right-radius: 0.5rem !important;
    text-align: right !important;
    font-weight: 700 !important;
    color: var(--cbp-primary-hover) !important;
}

/* ==========================================================================
   6. FOOTER ACTION BUTTONS (Submit, Add to cart)
   ========================================================================== */
#cbp-spv-wrapper .cbp-spv-footer {
    display: flex !important;
    gap: 0.75rem !important;
}

/* Primary Submit / Proceed Button */
#cbp-spv-wrapper .cbp-spv-s-btn {
    flex: 1.5 !important;
    height: 4.5rem !important;
    border-radius: 1rem !important;
    background-color: var(--cbp-primary-hover) !important;
    color: var(--cbp-text-dark) !important;
    font-weight: 900 !important;
    font-size: 1.2rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border: none !important;
    cursor: pointer !important;
    box-shadow: 0 10px 15px -3px var(--cbp-primary-shadow) !important;
}

#cbp-spv-wrapper .cbp-spv-s-btn:hover {
    filter: brightness(1.1) !important;
}

/* Secondary Action Button (e.g. Add To Cart) */
#cbp-spv-wrapper .cbp-spv-c-btn {
    flex: 1 !important;
    height: 4.5rem !important;
    border-radius: 1rem !important;
    background-color: transparent !important;
    color: var(--cbp-primary-hover) !important;
    border: 2px solid var(--cbp-primary-hover) !important;
    font-weight: 900 !important;
    font-size: 1.2rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    cursor: pointer !important;
}

#cbp-spv-wrapper .cbp-spv-c-btn:hover {
    background-color: rgba(234, 179, 8, 0.1) !important;
}

/* =================
RESPONSIVNESS 
================= */

@media (width < 425px) {
    #cbp-spv-wrapper .cbp-spv-p-title{
        font-size: 1.2rem !important;
    }
}