/* Dual IPTV Frontend Styles - v2.2 (Enhanced Visibility & UX) */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;700;900&family=Inter:wght@400;500;600&display=swap');

:root {
    --dual-primary: #e8fcaa;
    --dual-primary-dark: #c0d482;
    --dual-dark: #0a0a0a;
    --dual-light: #1a1a1a;
    --dual-medium: #2a2a2a;
    /* -- MODIFICATION -- Increased contrast for secondary text for better readability. */
    --dual-text: #ffffff;
    --dual-text-secondary: #ffffff; 
    --dual-border: #3a3a3a;
    --dual-success: #52c41a;
    --dual-danger: #ff4d4f;
    --dual-warning: #faad14;
    --font-heading: 'Poppins', sans-serif;
    --font-body: 'Poppins', sans-serif;
}

/* Base & Layout */
* { 
    box-sizing: border-box; 
    font-weight: 900 !important;
    /*font-size: 1.2rem;*/
    
}
h1.dual-main-title {
    color: #e8fcaa;
}

/* -- MODIFICATION -- Increased base font size for better readability for 40+ audience. */
.dual-account-container, .dual-affiliate-container { 
    max-width: unset; 
    margin: 40px auto; 
    padding: clamp(20px, 4vw, 40px); 
    background: var(--dual-dark); 
    color: var(--dual-text); 
    font-family: var(--font-body); 
    border-radius: 24px; 
    border: 1px solid var(--dual-border); 
    overflow: hidden; 
    font-size: 16px; /* Base font size */
}
.dual-section { display: none; animation: fadeIn 0.5s ease-out; }
.dual-section.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }

/* Loaders & Messages */
#dual-loading.active { display: flex; flex-direction: column; justify-content: center; align-items: center; min-height: 450px; }
.dual-loader { width: 50px; height: 50px; border: 4px solid var(--dual-border); border-top-color: var(--dual-primary); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.dual-loader-text, .dual-empty-cell, .dual-loading-modal { text-align: center; margin-top: 20px; font-size: 1.2rem; color: var(--dual-text-secondary); }
.dual-message-box { padding: 16px 20px; margin-bottom: 25px; border-radius: 12px; display: flex; align-items: center; gap: 12px; font-size: 1rem; font-weight: 600; color: white; animation: fadeIn 0.3s; }
.dual-message-icon { font-size: 1.2rem; }
.dual-message-text { flex-grow: 1; font-weight:900; }
.dual-message-close { cursor: pointer; font-size: 1.5rem; opacity: 0.7; transition: opacity 0.2s; background: none; border: none; color: inherit; padding: 0 5px; }
.dual-message-error { background: var(--dual-danger); }
.dual-message-success { background: var(--dual-success); }

/* Headers & Welcome Boxes */
.dual-welcome-box, .dual-verify-box { text-align: center; padding: clamp(25px, 5vw, 40px); background: var(--dual-light); border-radius: 20px; margin-bottom: 35px; border: 2px solid var(--dual-primary); }
h1, h2 {
    font-family: var(--font-heading) !important;
    font-weight: 900 !important;
    color: var(--dual-primary) !important;
}
.dual-main-title { font-size: clamp(2.2rem, 5vw, 2.8rem); margin: 0 0 1rem; }
.dual-subtitle { font-size: 1.2rem; color: var(--dual-text-secondary); margin-top: 0; line-height: 1.5; }

/* Forms & Buttons */
.dual-form-group label { display: block; margin-bottom: 12px; font-size: 1.2rem; font-weight: 600; color: var(--dual-text-secondary); }
.dual-input {
    width: 100% !important;
    padding: 18px 20px !important;
    background: #000 !important;
    border: 2px solid #e8fcaa !important;
    border-radius: 14px !important;
    color: var(--dual-text) !important;
    font-size: 1.2rem !important;
    transition: all 0.2s !important;
}
.dual-input:focus { outline: none !important; border-color: #c1ff00 !important; box-shadow: 0 0 0 4px rgba(232, 252, 170, 0.15) !important; }
.dual-code-input { text-align: center; font-size: 2rem; letter-spacing: 0.8em; padding-left: calc(0.8em + 4px); font-family: monospace; font-weight: 700; }
.dual-btn { display: inline-flex; justify-content: center; align-items: center; gap: 0.5em; width: 100%; text-align: center; padding: 18px; border: none; border-radius: 14px; font-size: 1.2rem; font-family: var(--font-heading); font-weight: 700; cursor: pointer; transition: all 0.3s ease; text-transform: uppercase; letter-spacing: 1.5px; }
.dual-btn-primary { background: var(--dual-primary); color: var(--dual-dark); }
.dual-btn-primary:hover { background: #fff; transform: translateY(-2px); box-shadow: 0 4px 15px rgba(232, 252, 170, 0.2); }
#dual-timing { font-size: 1rem; color: var(--dual-warning); font-weight: 600; }

/* Account & Affiliate Dashboards */
.dual-header-top { display: flex; justify-content: space-between; align-items: center; padding: clamp(15px, 3vw, 25px); background: var(--dual-light); border-radius: 20px; margin-bottom: 30px; flex-wrap: wrap; gap: 20px; }
#dual-welcome-name, .dual-header-top h2 { font-size: clamp(1.8rem, 4vw, 2.2rem); margin: 0; line-height: 1.2; color: var(--dual-text); }
.dual-account-email { color: var(--dual-text-secondary); font-size: 1.1rem; }
.dual-header-actions { display: flex; gap: 10px; flex-shrink: 0; }
.dual-header-actions .dual-btn, .dual-btn-logout, .dual-btn-affiliate { width: auto; font-size: 1rem; }
.dual-btn-affiliate { background: var(--dual-success); color: white; padding: 12px 22px; }
.dual-btn-logout { background: var(--dual-danger); color: white; padding: 12px 22px; }

/* Tables */
.dual-orders-section, .dual-referrals-section { background: var(--dual-light); padding: clamp(20px, 4vw, 40px); border-radius: 20px; }
.dual-orders-section h3, .dual-referrals-section h3 { font-size: 1.8rem; font-family: var(--font-heading); color: var(--dual-primary); margin-top: 0; margin-bottom: 20px;}
.dual-orders-table-container, .dual-table-container { overflow-x: auto; -webkit-overflow-scrolling: touch; }
#dual-orders-table, #dual-referrals-table { width: 100%; min-width: 600px; border-collapse: separate; border-spacing: 0; }
th { background: var(--dual-medium); color: var(--dual-primary); padding: 18px; text-align: left; font-family: var(--font-heading); white-space: nowrap; font-size: 1.1rem;}
th:first-child { border-radius: 12px 0 0 0; } th:last-child { border-radius: 0 12px 0 0; }
td {
    padding: 20px 18px !important;
    border-bottom: 1px solid var(--dual-border) !important;
    vertical-align: middle !important;
    font-size: 1.1rem !important;
    color: var(--dual-text) !important;
}
tbody tr:last-child td { border-bottom: none; }
.dual-btn-view { background: var(--dual-primary); color: #000; padding: 10px 20px; font-weight: 700; border-radius: 8px; font-size: 1rem; border: none; cursor: pointer; transition: all 0.2s; }
.dual-btn-view:hover { background: #fff; transform: scale(1.05); }
.dual-pagination-container { text-align: center; margin-top: 25px; display: flex; align-items: center; justify-content: center; gap: 15px;}
.dual-pagination-container .dual-btn { width: auto; padding: 10px 20px; margin: 0 5px; background: var(--dual-medium); }
.dual-pagination-container .dual-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.dual-page-info { font-weight: 600; color: var(--dual-text-secondary); }

/* Modals */
.dual-modal { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); z-index: 10000; overflow-y: auto; padding: 20px; backdrop-filter: blur(8px); }
.dual-modal.active { display: flex !important; align-items: center; justify-content: center; }
.dual-modal-content { background: var(--dual-light); padding: clamp(25px, 5vw, 40px); border-radius: 20px; max-width: 900px; width: 100%; position: relative; border: 2px solid var(--dual-primary); max-height: 90vh; overflow-y: auto; animation: slideUp 0.4s ease-out; margin: auto; display: block; }
@keyframes slideUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
.dual-close-modal { position: absolute; top: 15px; right: 15px; width: 40px; height: 40px; font-size: 2rem; line-height: 1; cursor: pointer; color: #aaa; transition: all 0.2s; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--dual-dark); border: none; }
.dual-close-modal:hover { color: var(--dual-primary); transform: rotate(90deg); }
.dual-modal h2 { font-size: clamp(1.8rem, 4vw, 2.2rem); margin-top: 0; margin-bottom: 10px; }
.dual-modal-subtitle { font-size: 1.1rem; color: var(--dual-text-secondary); margin-top: 0; margin-bottom: 30px;}

/* Order Details Modal */
#dual-order-details { display: flex !important; flex-direction: column; gap: 20px; }
.dual-detail-section { padding: 25px; background: var(--dual-dark); border-radius: 15px; border: 1px solid var(--dual-primary); }
.dual-detail-section h4 { font-family: var(--font-heading); color: var(--dual-primary); margin: 0 0 20px; font-size: 1.4rem; }
.dual-detail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; }
.dual-detail-label { font-size: 1rem; color: var(--dual-text-secondary); display: block; margin-bottom: 6px; }
.dual-detail-value { font-size: 1.1rem; font-weight: 600; word-break: break-word; color: var(--dual-text); display: block; }
.dual-products-list { list-style: none; padding: 0; margin: 0; }
.dual-products-list li { display: flex; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--dual-border); color: var(--dual-text); font-size: 1.1rem;}
.dual-products-list li:last-child { border: none; }
.dual-btn-view-iptv { background: var(--dual-primary); color: #000; border: none; padding: 15px 25px; border-radius: 12px; font-weight: 700; cursor: pointer; transition: all 0.2s; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 1px; width: 100%;}
.dual-btn-view-iptv:hover { background: #fff; transform: translateY(-2px); }

/* -- MODIFICATION -- New styles for the improved, multi-connection M3U modal */
.dual-m3u-modal-content { max-width: 800px; }
#dual-m3u-connections-container { display: flex; flex-direction: column; gap: 25px; }
.dual-connection-card {     background: #4f4f4f;
    border: 2px solid var(--dual-primary);
    border-radius: 16px;
    padding: 25px;}
.dual-connection-card h3 { margin: 0 0 20px; color: var(--dual-primary); font-size: 1.5rem; }
.dual-connection-card label { display: block; font-weight: 600; color: var(--dual-text-secondary); margin-bottom: 8px; font-size: 1.1rem;}
.dual-copy-field { display: flex; margin-bottom: 15px; }
.dual-copy-field input, .dual-copy-field textarea { 
    flex: 1;
    min-width: 0;
    background: #ffffff;
    border-radius: 8px 0 0 8px;
    border: 2px solid var(--dual-primary);
    border-right: none;
    padding: 14px;
    font-family: monospace;
    color: #000000;
    font-size: 1rem;
    
}
.dual-copy-field textarea { resize: vertical; height: 110px; }
.dual-copy-btn { background: var(--dual-primary); color: #000; border: 2px solid var(--dual-primary); padding: 0 20px; border-radius: 0 8px 8px 0; font-weight: 700; flex-shrink: 0; cursor: pointer; font-size: 1rem; position: relative; transition: background-color 0.2s; }
.dual-copy-btn.copied { background-color: var(--dual-success); color: white; border-color: var(--dual-success); }
.dual-copy-btn.copied::after { content: '✔'; margin-left: 5px; }

.dual-xtream-toggle {border: 2px solid var(--dual-text); background: var(--dual-medium); color: var(--dual-text); width: 100%; padding: 15px; border-radius: 8px; font-weight: 600; font-size: 1.1rem; cursor: pointer; text-align: left; display: flex; justify-content: space-between; align-items: center; margin-top: 10px;}
.dual-xtream-toggle::after { content: '▼'; transition: transform 0.3s ease; }
.dual-xtream-toggle.active::after { transform: rotate(180deg); }
.dual-xtream-details { max-height: 0; overflow: hidden; transition: max-height 0.4s ease-out, padding-top 0.4s ease-out; }
.dual-xtream-details.active { max-height: 500px; padding-top: 20px; } /* -- MODIFICATION -- Smooth accordion animation */
.dual-credential-grid {  grid-template-columns: 1fr 1fr; gap: 15px; }
@media (max-width: 600px) { .dual-credential-grid { grid-template-columns: 1fr; } }

/* Status Badges */
[class*="dual-status-"] { padding: 6px 12px; border-radius: 8px; font-size: 0.9rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; }
.dual-status-completed { background: rgba(82, 196, 26, 0.2); color: #73d13d; }
.dual-status-processing { background: rgba(250, 173, 20, 0.6); color: #ffc53d; }
.dual-status-pending, .dual-status-on-hold { background: rgba(108, 117, 125, 0.2); color: #8c8c8c; }
.dual-status-cancelled, .dual-status-failed, .dual-status-refunded { background: rgba(255, 77, 79, 0.2); color: #ff7875; }

/* Affiliate-Specific Styles (Unchanged) */
.dual-features { display: flex; justify-content: center; gap: 25px; margin-top: 25px; flex-wrap: wrap; }
.dual-feature { display: flex; align-items: center; gap: 12px; font-size: 1.1rem; font-weight: 600; padding: 12px 20px; background: rgba(232, 252, 170, 0.05); border-radius: 12px; }
.dual-feature-icon { font-size: 1.8rem; }
.dual-earnings-box { background: var(--dual-light); border: 2px solid var(--dual-primary); border-radius: 20px; padding: 40px; margin-bottom: 35px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 25px; }
.dual-earnings-amount { font-size: clamp(2.5rem, 6vw, 3.5rem); font-weight: 900; color: var(--dual-primary); line-height: 1; }
.dual-earnings-label { font-size: 1.2rem; color: var(--dual-text-secondary); margin-top: 8px; }
.dual-btn-redeem { background: var(--dual-success); color: white; font-size: 1.2rem; }
.dual-link-container { display: flex; gap: 15px; margin-bottom: 35px; flex-wrap: wrap; }
.dual-link-input { flex: 1; min-width: 250px; }
.dual-btn-copy { background: var(--dual-primary); color: var(--dual-dark); flex-shrink: 0; width: auto; }
.dual-social-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 15px; }
.dual-social-btn { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 14px; border-radius: 12px; color: white; font-weight: 700; transition: transform 0.2s; border: none; cursor: pointer; }
.dual-social-btn:hover { transform: translateY(-3px); }
.dual-social-btn svg { width: 22px; height: 22px; fill: currentColor; }
.dual-whatsapp { background: #25D366; } .dual-facebook { background: #1877F2; }
.dual-messenger { background: #0084FF; } .dual-twitter { background: #1DA1F2; }
.dual-telegram { background: #0088cc; } .dual-email { background: #EA4335; }
.dual-products-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; }
.dual-product-card { background: var(--dual-dark); border: 2px solid var(--dual-border); border-radius: 18px; padding: 25px; text-align: center; cursor: pointer; transition: all 0.2s ease-in-out; }
.dual-product-card:hover { border-color: var(--dual-primary); transform: translateY(-5px); }
.dual-product-image { width: 100%; height: 160px; object-fit: cover; border-radius: 12px; margin-bottom: 15px; }
.dual-product-title { font-size: 1.1rem; font-weight: 600; margin-bottom: 10px; }
.dual-product-price { font-size: 1.8rem; color: var(--dual-primary); font-weight: 900; }
.dual-btn-back { background: var(--dual-border); color: white; width: auto; margin-bottom: 20px; }