/* ========================================
   ORDERS PAGE STYLES
   Loaded only on my-account/orders page
   ======================================== */

/* Orders Page Package Actions (PDF/Invitation items) */
.ipw-order-package-actions {
    margin-top: 10px;
    padding: 15px;
    background: #f9f9f9;
    border-radius: 5px;
    border: 1px solid #ddd;
}

.ipw-package-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    padding: 10px;
    background: #fff;
    border-radius: 4px;
    border: 1px solid #e1e1e1;
}

.ipw-package-item:last-child {
    margin-bottom: 0;
}

.ipw-package-info {
    flex: 1;
}

.ipw-package-info strong {
    color: #333;
    font-size: 14px;
}

.ipw-package-info small {
    color: #666;
    font-style: italic;
}

.ipw-package-stats {
    color: #777;
    font-size: 12px;
    margin-top: 3px;
    display: block;
}

.ipw-package-buttons {
    display: flex;
    gap: 8px;
    align-items: center;
}

.ipw-package-buttons .button {
    font-size: 12px !important;
    padding: 6px 12px !important;
    height: auto !important;
    line-height: 1.2 !important;
    white-space: nowrap;
}

.ipw-use-edit-btn {
    background: #0073aa !important;
    color: white !important;
    border-color: #0073aa !important;
}

.ipw-use-edit-btn:hover:not(:disabled) {
    background: #005a87 !important;
    border-color: #005a87 !important;
}

.ipw-download-btn {
    background: #00a32a !important;
    color: white !important;
    border-color: #00a32a !important;
}

.ipw-download-btn:hover:not(:disabled) {
    background: #007c20 !important;
    border-color: #007c20 !important;
}

.ipw-expired {
    color: #d63638;
    font-weight: bold;
    font-style: italic;
    background: #fff2f2;
    padding: 6px 12px;
    border-radius: 3px;
    border: 1px solid #f5c6cb;
}

/* Status badge styles */
.ipw-status {
    display: inline-block;
    padding: 4px 9px;
    border-radius: 14px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1;
    background: #eee;
    color:#444;
    letter-spacing:.3px;
}
.ipw-status.active { background:#e6f9ee; color:#1a7f37; }
.ipw-status.grace { background:#fff7e6; color:#b26b00; }
.ipw-status.expired { background:#fdecea; color:#d63638; }

/* Responsive table (My Account > Invitation Packages) */
.ipw-responsive-table { width:100%; border-collapse: collapse; }
.ipw-responsive-table th, .ipw-responsive-table td { padding:10px 12px; }
.ipw-responsive-table th { background:#f7f7f7; font-weight:600; font-size:13px; }
.ipw-responsive-table tbody tr:nth-child(even){ background:#fcfcfc; }

/* ========================================
   VIDEO ORDER ITEM STYLES
   ======================================== */

.ipw-video-order-item {
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%) !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin: 10px 0 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
}

.ipw-video-product-name {
    margin-bottom: 15px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #eee !important;
}

.ipw-video-product-name strong {
    font-size: 16px !important;
    color: #333 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.ipw-video-product-name strong::before {
    content: "\1F3AC" !important;
    font-size: 20px !important;
}

.ipw-video-status-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
}

.ipw-video-status {
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
    padding: 15px !important;
    border-radius: 8px !important;
    background: #fff !important;
    border: 1px solid #e5e5e5 !important;
}

.ipw-video-status-icon {
    font-size: 28px !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
}

.ipw-video-status-text {
    flex: 1 !important;
}

.ipw-video-message {
    display: block !important;
    font-size: 14px !important;
    color: #555 !important;
    font-weight: 500 !important;
    margin-bottom: 8px !important;
}

/* Render reference ID for support/debugging */
.ipw-video-render-id {
    display: block !important;
    font-size: 11px !important;
    color: #999 !important;
    font-family: monospace !important;
    margin-top: 2px !important;
    margin-bottom: 4px !important;
    user-select: all !important;
}

/* Progress bar */
.ipw-video-progress-bar {
    width: 100% !important;
    height: 8px !important;
    background: #e9ecef !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    margin-top: 8px !important;
}

.ipw-video-progress-fill {
    height: 100% !important;
    background: linear-gradient(90deg, #0073aa, #00a0d2) !important;
    border-radius: 4px !important;
    transition: width 0.5s ease !important;
    width: 0% !important;
}

/* Status variations */
.ipw-video-status-pending {
    background: #fff8e6 !important;
    border-color: #ffc107 !important;
}

.ipw-video-status-queued {
    background: #e8f4fd !important;
    border-color: #0073aa !important;
}

.ipw-video-status-processing {
    background: #e8f4fd !important;
    border-color: #0073aa !important;
}

.ipw-video-status-completed {
    background: #e8f8e8 !important;
    border-color: #28a745 !important;
}

.ipw-video-status-error {
    background: #fde8e8 !important;
    border-color: #dc3545 !important;
}

/* Actions */
.ipw-video-actions {
    display: flex !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    margin-top: 10px !important;
}

.ipw-check-video-status-btn {
    background: #0073aa !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 20px !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.ipw-check-video-status-btn:hover {
    background: #005a87 !important;
    transform: translateY(-1px) !important;
}

.ipw-check-video-status-btn:disabled {
    background: #ccc !important;
    cursor: not-allowed !important;
    transform: none !important;
}

.ipw-video-download-btn {
    background: #28a745 !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 24px !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    align-items: center !important;
    gap: 8px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

/* Only show download button in completed state */
.ipw-video-download-btn {
    display: none !important;
}

.ipw-video-order-item[data-status="completed"] .ipw-video-download-btn {
    display: inline-flex !important;
}

/* Only show check/refresh button in non-completed states */
.ipw-video-order-item[data-status="completed"] .ipw-check-video-status-btn {
    display: none !important;
}

/* Only show trigger button in queued state */
.ipw-trigger-render-btn {
    display: none !important;
}

.ipw-video-order-item[data-status="queued"] .ipw-trigger-render-btn {
    display: inline-flex !important;
}

/* Hide all action buttons in pending state */
.ipw-video-order-item[data-status="pending"] .ipw-video-actions {
    display: none !important;
}

/* Hide check-status button when processing but not yet having a job ID */
.ipw-video-order-item[data-status="queued"] .ipw-check-video-status-btn {
    display: none !important;
}

/* Cancel button: hidden by default, visible only during processing (queued/rendering) */
.ipw-cancel-render-btn {
    display: none !important;
    color: #a00 !important;
    border-color: #a00 !important;
    background: #fff !important;
}

.ipw-cancel-render-btn:hover {
    background: #a00 !important;
    color: #fff !important;
}

.ipw-video-order-item[data-status="processing"] .ipw-cancel-render-btn {
    display: inline-flex !important;
}

/* Video thankyou section on order-received page */
.ipw-video-thankyou-section {
    margin: 20px 0 !important;
}

.ipw-video-thankyou-section h2 {
    font-size: 20px !important;
    margin-bottom: 15px !important;
}

.ipw-video-download-btn::before {
    content: "\2B07\FE0F" !important;
}

.ipw-video-download-btn:hover {
    background: #1e7e34 !important;
    color: #fff !important;
    transform: translateY(-1px) !important;
}

/* Spinner animation */
.ipw-spinner {
    display: inline-block !important;
    width: 24px !important;
    height: 24px !important;
    border: 3px solid #e9ecef !important;
    border-top-color: #0073aa !important;
    border-radius: 50% !important;
    animation: ipw-spin 1s linear infinite !important;
}

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

/* Video info details */
.ipw-video-info-details {
    display: flex !important;
    gap: 20px !important;
    flex-wrap: wrap !important;
    font-size: 12px !important;
    color: #666 !important;
    margin-top: 10px !important;
    padding-top: 10px !important;
    border-top: 1px solid #eee !important;
}

.ipw-video-info-item {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
}

.ipw-video-info-item strong {
    color: #333 !important;
}

/* =========================================================================
   EDIT DETAILS BUTTON
   Show in completed/error, hide during processing/pending/queued
   ========================================================================= */

.ipw-edit-details-btn {
    display: none !important;
    background: #17a2b8 !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 20px !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.ipw-edit-details-btn:hover {
    background: #138496 !important;
    transform: translateY(-1px) !important;
}

/* Show edit button only in completed or error states */
.ipw-video-order-item[data-status="completed"] .ipw-edit-details-btn,
.ipw-video-order-item[data-status="error"] .ipw-edit-details-btn {
    display: inline-flex !important;
}

/* =========================================================================
   PACKAGE STATUS BAR
   ========================================================================= */

.ipw-video-package-status {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    margin: 8px 0 12px !important;
    font-size: 13px !important;
}

.ipw-pkg-badge {
    display: inline-block !important;
    padding: 3px 10px !important;
    border-radius: 12px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
}

.ipw-pkg-active {
    background: #d4edda !important;
    color: #155724 !important;
    border: 1px solid #c3e6cb !important;
}

.ipw-pkg-expired {
    background: #f8d7da !important;
    color: #721c24 !important;
    border: 1px solid #f5c6cb !important;
}

.ipw-pkg-expiry {
    color: #666 !important;
    font-size: 12px !important;
}

.ipw-pkg-scope {
    font-size: 11px !important;
    color: #888 !important;
    margin-top: 4px !important;
    line-height: 1.4 !important;
}

.ipw-pkg-scope-label {
    font-weight: 600 !important;
    color: #666 !important;
}

.ipw-pkg-scope-cats {
    font-style: italic !important;
}

/* =========================================================================
   R2 VIDEO HISTORY TABLE
   ========================================================================= */

.ipw-video-history {
    margin-top: 16px !important;
    border-top: 1px solid #e9ecef !important;
    padding-top: 12px !important;
}

.ipw-video-history h4 {
    font-size: 14px !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}

.ipw-video-history-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 13px !important;
}

.ipw-video-history-table th {
    background: #f8f9fa !important;
    padding: 8px 12px !important;
    text-align: left !important;
    font-weight: 600 !important;
    color: #495057 !important;
    border-bottom: 2px solid #dee2e6 !important;
}

.ipw-video-history-table td {
    padding: 8px 12px !important;
    border-bottom: 1px solid #eee !important;
    vertical-align: middle !important;
}

.ipw-video-history-table tr:last-child td {
    border-bottom: none !important;
}

.ipw-video-history-table .button-small {
    font-size: 12px !important;
    padding: 4px 10px !important;
    border-radius: 4px !important;
    text-decoration: none !important;
}

.ipw-link-expired {
    color: #dc3545 !important;
    font-weight: 600 !important;
    font-size: 12px !important;
}

/* Package tier label next to product name */
.ipw-pkg-tier-label {
    color: #6c63ff !important;
    font-weight: 600 !important;
}

/* =========================================================================
   PREVENT WooCommerce responsive table CSS from leaking into nested table
   ========================================================================= */

.ipw-video-history-table,
.ipw-video-history-table thead,
.ipw-video-history-table tbody,
.ipw-video-history-table tr,
.ipw-video-history-table th,
.ipw-video-history-table td {
    display: revert !important;
}

.ipw-video-history-table thead {
    display: table-header-group !important;
}

.ipw-video-history-table tbody {
    display: table-row-group !important;
}

.ipw-video-history-table tr {
    display: table-row !important;
}

.ipw-video-history-table th,
.ipw-video-history-table td {
    display: table-cell !important;
}

.ipw-video-history-table td::before,
.ipw-video-history-table th::before {
    display: none !important;
    content: none !important;
}

/* ========================================
   ORDERS PAGE MOBILE RESPONSIVE
   ======================================== */

@media (max-width: 768px) {
    .ipw-package-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .ipw-package-buttons {
        width: 100%;
        justify-content: space-between;
    }

    .ipw-package-buttons .button {
        flex: 1;
    }

    /* Account page responsive table */
    .ipw-responsive-table thead { display:none; }
    .ipw-responsive-table, .ipw-responsive-table tbody, .ipw-responsive-table tr, .ipw-responsive-table td { display:block; width:100%; }
    .ipw-responsive-table tr { background:#fff; border:1px solid #e5e5e5; border-radius:6px; margin:0 0 14px; padding:6px 0 4px; box-shadow:0 2px 4px rgba(0,0,0,0.04); }
    .ipw-responsive-table td { border:none !important; position:relative; padding:8px 12px 8px 118px; font-size:13px; line-height:1.35; }
    .ipw-responsive-table td:before { content:attr(data-col-label); position:absolute; left:12px; top:50%; transform:translateY(-50%); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.5px; color:#666; width:95px; line-height:1.1; }
    .ipw-responsive-table td:first-child { border-top:none; }
    .ipw-responsive-table td:last-child { padding-bottom:12px; }
    .ipw-responsive-table td .ipw-status { margin-top:2px; }

    /* ─── WooCommerce orders table: fix Actions column on mobile ─── */
    /* The Actions <td> contains ipw-video-order-item / ipw-order-package-actions.
       WooCommerce responsive table sets td { padding-left: ~43%; } and td::before
       with column title. We need to override this for the Actions cell so our
       card-like content gets full width. */
    .woocommerce-orders-table .woocommerce-orders-table__cell-order-actions,
    table.shop_table_responsive tr td.woocommerce-orders-table__cell-order-actions {
        padding-left: 0 !important;
        padding-right: 0 !important;
        padding-bottom: 12px !important;
    }

    /* Hide the "Actions:" pseudo-label — our cards already have their own headers */
    .woocommerce-orders-table .woocommerce-orders-table__cell-order-actions::before,
    table.shop_table_responsive tr td.woocommerce-orders-table__cell-order-actions::before {
        display: none !important;
        content: none !important;
    }

    /* Also fix the Order # cell which can get cramped */
    .woocommerce-orders-table .woocommerce-orders-table__cell-order-number::before,
    table.shop_table_responsive tr td.woocommerce-orders-table__cell-order-number::before {
        float: none !important;
        display: block !important;
        margin-bottom: 4px !important;
    }

    /* Video order items mobile */
    .ipw-video-order-item {
        padding: 12px !important;
        overflow-x: hidden !important;
        margin: 4px 8px !important;
    }

    .ipw-video-product-name strong {
        font-size: 14px !important;
        flex-wrap: wrap !important;
    }

    .ipw-video-product-name strong::before {
        font-size: 16px !important;
    }

    .ipw-video-status {
        flex-direction: column !important;
        text-align: center !important;
        gap: 10px !important;
        padding: 10px !important;
    }

    .ipw-video-actions {
        flex-direction: column !important;
        gap: 8px !important;
        justify-content: center !important;
    }

    .ipw-video-actions .button,
    .ipw-video-actions a.button {
        width: 100% !important;
        text-align: center !important;
        box-sizing: border-box !important;
    }

    .ipw-video-info-details {
        flex-direction: column !important;
        gap: 4px !important;
        justify-content: center !important;
    }

    .ipw-video-product-name {
        word-break: break-word !important;
        font-size: 14px !important;
    }

    .ipw-video-product-name .ipw-pkg-tier-label {
        display: block !important;
        margin-top: 2px !important;
    }

    .ipw-video-package-status {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 6px !important;
        font-size: 12px !important;
    }

    .ipw-pkg-scope {
        font-size: 11px !important;
        line-height: 1.5 !important;
    }

    /* Package actions (non-video PDF items) mobile */
    .ipw-order-package-actions {
        padding: 10px !important;
        margin: 4px 8px !important;
    }

    .ipw-package-info small {
        font-size: 12px !important;
    }

    .ipw-package-stats {
        font-size: 11px !important;
    }

    /* History table: stack into vertical cards on mobile */
    .ipw-video-history-table {
        font-size: 12px !important;
    }

    .ipw-video-history-table thead {
        display: none !important;
    }

    .ipw-video-history-table,
    .ipw-video-history-table tbody {
        display: block !important;
        width: 100% !important;
    }

    .ipw-video-history-table tr {
        display: block !important;
        margin-bottom: 10px !important;
        padding: 10px !important;
        border: 1px solid #e9ecef !important;
        border-radius: 6px !important;
        background: #fafbfc !important;
    }

    .ipw-video-history-table td {
        display: block !important;
        padding: 4px 0 !important;
        border-bottom: none !important;
        text-align: left !important;
    }

    /* Show labels via data-label attribute on mobile */
    .ipw-video-history-table td::before {
        display: inline !important;
        content: attr(data-label) !important;
        font-weight: 600 !important;
        color: #495057 !important;
        margin-right: 6px !important;
    }
}

/* ========================================
   MY ACTIVE PACKAGES SUMMARY
   ======================================== */

.ipw-my-packages-summary {
    margin-bottom: 28px;
    padding: 0;
}

.ipw-my-packages-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #1a1a2e !important;
    margin: 0 0 14px 0 !important;
    padding: 0 !important;
}

.ipw-packages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 14px;
}

.ipw-package-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    transition: box-shadow 0.2s ease;
}

.ipw-package-card:hover {
    box-shadow: 0 3px 10px rgba(0,0,0,0.1);
}

.ipw-package-card.ipw-pkg-active {
    border-left: 4px solid #16a34a;
}

.ipw-package-card.ipw-pkg-grace {
    border-left: 4px solid #f59e0b;
}

.ipw-package-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
    border-bottom: 1px solid #e2e8f0;
}

.ipw-package-card-name {
    font-size: 15px;
    font-weight: 700;
    color: #1e293b;
}

.ipw-package-card-type {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #64748b;
    background: #e2e8f0;
    padding: 3px 8px;
    border-radius: 4px;
}

.ipw-package-card-body {
    padding: 12px 16px;
}

/* Compact summary row */
.ipw-package-card-summary {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px 16px;
    font-size: 13px;
    color: #475569;
    line-height: 1.5;
}

.ipw-summary-item strong {
    color: #1e293b;
}

.ipw-summary-sep {
    color: #cbd5e1;
    font-size: 14px;
}

.ipw-toggle-details {
    background: none;
    border: none;
    color: #2563eb;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    padding: 2px 6px;
    margin-left: auto;
    white-space: nowrap;
    transition: color 0.15s;
}

.ipw-toggle-details:hover {
    color: #1d4ed8;
    text-decoration: underline;
}

.ipw-package-card-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 5px 0;
    border-bottom: 1px solid #f1f5f9;
    gap: 12px;
}

.ipw-package-card-row:last-child {
    border-bottom: none;
}

.ipw-card-label {
    font-size: 13px;
    color: #64748b;
    font-weight: 500;
    flex-shrink: 0;
    white-space: nowrap;
}

.ipw-card-value {
    font-size: 13px;
    color: #1e293b;
    font-weight: 600;
    text-align: right;
    word-break: break-word;
    line-height: 1.4;
}

.ipw-cat-link {
    color: #2563eb;
    text-decoration: none;
    transition: color 0.15s;
}
.ipw-cat-link:hover {
    color: #1d4ed8;
    text-decoration: underline;
}

@media (max-width: 480px) {
    .ipw-packages-grid {
        grid-template-columns: 1fr;
    }

    .ipw-package-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    .ipw-package-card-body {
        padding: 10px 12px;
    }

    .ipw-package-card-row {
        flex-direction: column;
        gap: 2px;
    }

    .ipw-card-value {
        text-align: left;
    }
}
