/* ── Tapplaza Affiliate Ultimate — Frontend v5 ──────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root {
    --tf-blue:#4361ee;--tf-blue-lt:#eef1ff;--tf-green:#10b981;--tf-green-lt:#ecfdf5;
    --tf-red:#ef4444;--tf-red-lt:#fef2f2;--tf-yellow:#f59e0b;--tf-yellow-lt:#fffbeb;
    --tf-teal:#0891b2;--tf-teal-lt:#ecfeff;--tf-border:#e4e7ef;--tf-text:#1a1d2e;
    --tf-muted:#6b7491;--tf-radius:12px;--tf-font:'DM Sans',-apple-system,sans-serif;
    --tf-mono:'DM Mono','Courier New',monospace;
}
.tap-dash,.tap-checkout,.tap-alert{font-family:var(--tf-font);font-size:15px;line-height:1.55}

/* Alerts */
.tap-alert{padding:13px 17px;border-radius:10px;font-size:.9rem;font-weight:500;margin-bottom:16px;border:1.5px solid}
.tap-alert a{color:inherit;font-weight:700}
.tap-alert--success{background:var(--tf-green-lt);color:#065f46;border-color:#a7f3d0}
.tap-alert--warning{background:var(--tf-yellow-lt);color:#92400e;border-color:#fde68a}
.tap-alert--error{background:var(--tf-red-lt);color:#991b1b;border-color:#fca5a5}
.tap-alert--info{background:var(--tf-blue-lt);color:#1e3a8a;border-color:#c7d2fd}

/* Dashboard wrapper */
.tap-dash{max-width:780px}

/* Stats row */
.tap-dash__stats{display:flex;gap:14px;margin-bottom:26px;flex-wrap:wrap}
.tap-dash__stat{flex:1 1 130px;border-radius:var(--tf-radius);padding:18px 16px;text-align:center;border:1.5px solid transparent}
.tap-dash__stat--blue  {background:var(--tf-blue-lt);border-color:#c7d2fd}
.tap-dash__stat--indigo{background:#eef2ff;border-color:#c7d2fe}
.tap-dash__stat--teal  {background:var(--tf-teal-lt);border-color:#a5f3fc}
.tap-dash__stat--green {background:var(--tf-green-lt);border-color:#a7f3d0}
.tap-dash__stat-icon{font-size:1.4rem;margin-bottom:4px}
.tap-dash__stat-val{font-size:1.75rem;font-weight:700;color:var(--tf-text);line-height:1.1}
.tap-dash__stat-lbl{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--tf-muted);margin-top:3px}

/* Tabs */
.tap-dash__tabs{display:flex;gap:4px;border-bottom:2px solid var(--tf-border);margin-bottom:22px;flex-wrap:wrap}
.tap-dash__tab{padding:9px 18px;font-size:.85rem;font-weight:600;background:transparent;border:none;border-bottom:2.5px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--tf-muted);font-family:var(--tf-font);border-radius:7px 7px 0 0;transition:all .15s}
.tap-dash__tab:hover{color:var(--tf-text);background:#f5f6fa}
.tap-dash__tab--active{color:var(--tf-blue);border-bottom-color:var(--tf-blue);background:var(--tf-blue-lt)}

/* Panels */
.tap-dash__panel{display:none}
.tap-dash__panel--active{display:block}

/* Code cards */
.tap-dash__code-card{background:#fff;border:1.5px solid var(--tf-border);border-radius:var(--tf-radius);padding:18px 20px;margin-bottom:14px;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:box-shadow .2s}
.tap-dash__code-card:hover{box-shadow:0 4px 18px rgba(0,0,0,.09)}
.tap-dash__code-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;flex-wrap:wrap;gap:8px}
.tap-code-badge{display:inline-block;background:var(--tf-blue-lt);color:var(--tf-blue);border:1.5px solid #c7d2fd;border-radius:8px;padding:3px 13px;font-size:.95rem;font-weight:700;letter-spacing:.12em;font-family:var(--tf-mono)}
.tap-dash__code-pills{display:flex;gap:10px;flex-wrap:wrap}
.tap-pill{display:inline-flex;align-items:center;gap:4px;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}
.tap-pill--blue  {background:var(--tf-blue-lt);color:var(--tf-blue)}
.tap-pill--green {background:var(--tf-green-lt);color:#065f46}
.tap-pill--red   {background:var(--tf-red-lt);color:#991b1b}
.tap-pill--yellow{background:var(--tf-yellow-lt);color:#92400e}
.tap-pill--gray  {background:#f1f3f9;color:#4b5563}
.tap-dash__link-row{display:flex;gap:8px;align-items:center}
.tap-dash__link-input{flex:1;padding:8px 12px;border:1.5px solid var(--tf-border);border-radius:9px;font-size:.8rem;color:var(--tf-muted);background:#fafbff;font-family:var(--tf-mono);cursor:text}
.tap-dash__copy-btn{padding:8px 18px;background:var(--tf-blue);color:#fff;border:none;border-radius:9px;font-size:.85rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap;font-family:var(--tf-font);box-shadow:0 2px 6px rgba(67,97,238,.2)}
.tap-dash__copy-btn:hover{background:#3451d1}

/* Banner section */
.tap-dash__banner-group{margin-bottom:28px}
.tap-dash__banner-campaign{font-size:1rem;font-weight:700;color:var(--tf-text);margin:0 0 14px;text-transform:capitalize}
.tap-dash__banner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.tap-dash__banner-card{background:#fff;border:1.5px solid var(--tf-border);border-radius:var(--tf-radius);overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.tap-dash__banner-preview{background:#f5f6fa;padding:12px;min-height:90px;display:flex;align-items:center;justify-content:center}
.tap-dash__banner-preview img{max-width:100%;max-height:130px;object-fit:contain}
.tap-dash__banner-meta{padding:10px 14px 6px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.tap-dash__banner-title{font-size:.83rem;font-weight:600;color:var(--tf-text);flex:1 0 100%}
.tap-dash__banner-code-row{padding:8px 14px 14px;display:flex;flex-direction:column;gap:8px}
.tap-dash__code-textarea{width:100%;padding:8px 10px;border:1.5px solid var(--tf-border);border-radius:8px;font-family:var(--tf-mono);font-size:.72rem;color:var(--tf-muted);background:#f9fafb;resize:vertical;min-height:60px;cursor:text}

/* Sales table */
.tap-dash__sales-table-wrap{overflow-x:auto}
.tap-table{width:100%;border-collapse:collapse;font-size:.86rem}
.tap-table thead th{text-align:left;padding:10px 14px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--tf-muted);background:#fafbff;border-bottom:1.5px solid var(--tf-border)}
.tap-table tbody td{padding:11px 14px;border-bottom:1px solid #f0f2f8;color:var(--tf-text);vertical-align:middle}
.tap-table tbody tr:last-child td{border-bottom:none}

/* Checkout */
.tap-checkout{max-width:480px;background:#fff;border:1.5px solid var(--tf-border);border-radius:var(--tf-radius);padding:28px;box-shadow:0 2px 10px rgba(0,0,0,.07)}
.tap-checkout__title{margin:0 0 20px;font-size:1.15rem;font-weight:700;color:var(--tf-text)}
.tap-checkout__field{margin-bottom:18px}
.tap-checkout__field label{display:block;margin-bottom:6px;font-size:.85rem;font-weight:600;color:var(--tf-text)}
.tap-checkout__input{width:100%;padding:11px 14px;border:1.5px solid var(--tf-border);border-radius:10px;font-size:1rem;color:var(--tf-text);font-family:var(--tf-font);transition:border-color .15s,box-shadow .15s;background:#fff}
.tap-checkout__input:focus{outline:none;border-color:var(--tf-blue);box-shadow:0 0 0 3.5px rgba(67,97,238,.12)}
.tap-checkout__btn{width:100%;padding:13px;background:var(--tf-blue);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .18s;font-family:var(--tf-font);box-shadow:0 2px 8px rgba(67,97,238,.25)}
.tap-checkout__btn:hover{background:#3451d1;box-shadow:0 4px 16px rgba(67,97,238,.35)}

/* ── Registration & Apply Forms ──────────────────────────────────────────── */
.tap-reg{font-family:var(--tf-font);max-width:560px;margin:0 auto;padding:20px}
.tap-reg__card{background:#fff;border:1.5px solid var(--tf-border);border-radius:20px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.1)}
.tap-reg__brand{background:linear-gradient(135deg,#4361ee,#7c3aed);padding:32px 36px;text-align:center}
.tap-reg__logo{font-size:2.8rem;margin-bottom:10px;line-height:1}
.tap-reg__title{margin:0 0 8px;color:#fff;font-size:1.4rem;font-weight:700}
.tap-reg__sub{margin:0;color:rgba(255,255,255,.8);font-size:.9rem;line-height:1.5}
.tap-reg form{padding:28px 36px}
.tap-reg__row{display:flex;gap:14px}
.tap-reg__row .tap-reg__field{flex:1}
.tap-reg__field{margin-bottom:18px}
.tap-reg__field label{display:block;margin-bottom:6px;font-size:.85rem;font-weight:600;color:#1a1d2e}
.tap-req{color:#ef4444}
.tap-reg__optional{color:#6b7491;font-weight:400}
.tap-reg__field input,.tap-reg__field select,.tap-reg__field textarea{width:100%;padding:10px 14px;border:1.5px solid #e4e7ef;border-radius:10px;font-size:.9rem;font-family:inherit;color:#1a1d2e;background:#fff;transition:border-color .15s,box-shadow .15s;appearance:none}
.tap-reg__field input:focus,.tap-reg__field select:focus,.tap-reg__field textarea:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3.5px rgba(67,97,238,.12)}
.tap-reg__field textarea{resize:vertical;min-height:80px}
.tap-reg__pw-wrap{position:relative}
.tap-reg__pw-wrap input{padding-right:44px}
.tap-reg__pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;line-height:1;color:#6b7491}
.tap-reg__pw-strength{margin-top:6px;height:4px;border-radius:4px;background:#e4e7ef;overflow:hidden;transition:all .3s}
.tap-reg__pw-strength-bar{height:100%;border-radius:4px;transition:width .3s,background .3s}
.tap-reg__field--check label{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.tap-reg__checkbox{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:.85rem;color:#374151;line-height:1.5}
.tap-reg__checkbox input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:#4361ee;cursor:pointer}
.tap-reg__checkbox a{color:#4361ee;font-weight:600}
.tap-reg__submit{display:block;width:100%;padding:13px;background:linear-gradient(135deg,#4361ee,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .18s;font-family:inherit;box-shadow:0 2px 10px rgba(67,97,238,.3);margin-top:4px}
.tap-reg__submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(67,97,238,.4)}
.tap-reg__submit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.tap-reg__login-link{text-align:center;margin:16px 0 0;font-size:.85rem;color:#6b7491}
.tap-reg__login-link a{color:#4361ee;font-weight:600}

/* Success state */
.tap-reg__success{padding:36px;text-align:center}
.tap-reg__success-icon{font-size:3rem;margin-bottom:16px}
.tap-reg__success h3{margin:0 0 12px;font-size:1.3rem;font-weight:700;color:#1a1d2e}
.tap-reg__success p{margin:0 0 10px;color:#6b7491;line-height:1.6}
.tap-reg__success-note{font-size:.82rem}

/* Apply shortcode */
.tap-apply{max-width:520px;margin:0 auto;font-family:var(--tf-font)}
.tap-apply__card{background:#fff;border:1.5px solid var(--tf-border);border-radius:20px;padding:36px;box-shadow:0 4px 24px rgba(0,0,0,.08);text-align:center}
.tap-apply--pending .tap-apply__card,.tap-apply--rejected .tap-apply__card{border-radius:16px;padding:32px}
.tap-apply__icon{font-size:3rem;margin-bottom:16px;line-height:1}
.tap-apply__title{margin:0 0 10px;font-size:1.3rem;font-weight:700;color:#1a1d2e}
.tap-apply__sub{color:#6b7491;line-height:1.6;margin:0 0 24px;font-size:.93rem}
.tap-apply__perks{background:#f5f6fa;border-radius:12px;padding:20px;margin-bottom:24px;text-align:left}
.tap-apply__perk{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:.9rem;color:#374151;font-weight:500}
.tap-apply__perk span{flex:1}
.tap-apply form{text-align:left}

/* Admin: filter tabs */
.tap-filter-tabs{display:flex;gap:6px;flex-wrap:wrap}
.tap-filter-tab{padding:7px 16px;border-radius:8px;font-size:.82rem;font-weight:600;text-decoration:none;color:#6b7491;background:#f5f6fa;border:1.5px solid #e4e7ef;transition:all .15s}
.tap-filter-tab:hover{background:#eef1ff;color:#4361ee;border-color:#c7d2fd}
.tap-filter-tab--active{background:#4361ee;color:#fff;border-color:#4361ee}
.tap-filter-tab--pending{position:relative}
.tap-notes-trigger{cursor:pointer;color:#4361ee;font-size:.82rem;font-weight:600;text-decoration:underline}

/* Inline form alert */
#tap-reg-msg .tap-form-error{background:#fef2f2;color:#991b1b;border:1.5px solid #fca5a5;border-radius:10px;padding:11px 16px;font-size:.88rem;font-weight:500;margin-bottom:16px}
#tap-reg-msg .tap-form-success{background:#ecfdf5;color:#065f46;border:1.5px solid #a7f3d0;border-radius:10px;padding:11px 16px;font-size:.88rem;font-weight:500;margin-bottom:16px}
#tap-apply-msg .tap-form-error{background:#fef2f2;color:#991b1b;border:1.5px solid #fca5a5;border-radius:10px;padding:11px 16px;font-size:.88rem;font-weight:500;margin-bottom:16px}
