/* ══════════════ Partner Portal ══════════════ */
:root { --blue:#3B82F6; --blue-dark:#1D4ED8; --green:#10B981; --red:#EF4444; --orange:#F59E0B; --purple:#8B5CF6; --text:#0F172A; --text2:#475569; --text3:#94A3B8; --border:#E2E8F0; --bg:#F8FAFC; --white:#FFFFFF; --radius:14px; }
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}

/* ── Login ── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#EFF6FF,#F8FAFC)}
.login-card{background:var(--white);border-radius:20px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 8px 40px rgba(0,0,0,.06)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.login-logo img{width:44px;height:44px;border-radius:12px;object-fit:contain}
.login-logo span{font-size:20px;font-weight:800;color:var(--text)}
.login-logo em{font-style:normal;color:var(--blue);font-weight:600;font-size:13px;background:#EFF6FF;padding:3px 10px;border-radius:20px;margin-left:4px}
.login-title{font-size:24px;font-weight:800;margin-bottom:6px}
.login-sub{font-size:14px;color:var(--text2);margin-bottom:28px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px}
.field input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;color:var(--text);background:var(--bg);outline:none;transition:border .2s}
.field input:focus{border-color:var(--blue)}
.btn-primary{width:100%;padding:14px;background:var(--blue);color:#fff;font-size:16px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:background .2s}
.btn-primary:hover{background:var(--blue-dark)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.error-box{background:#FEF2F2;color:#DC2626;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:16px}
.switch-row{text-align:center;margin-top:20px;font-size:14px;color:var(--text3)}
.switch-row a{color:var(--blue);font-weight:600;text-decoration:none;cursor:pointer}
.back-link{display:block;text-align:center;margin-top:16px;color:var(--blue);font-size:14px;font-weight:600;text-decoration:none}

/* ── Dashboard Layout ── */
.dashboard{display:flex;min-height:100vh}
.sidebar{width:260px;background:var(--white);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column}
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 8px;margin-bottom:32px}
.sidebar-logo img{width:36px;height:36px;border-radius:10px;object-fit:contain}
.sidebar-logo span{font-weight:800;font-size:17px}
.sidebar-logo em{font-style:normal;font-size:11px;color:var(--blue);background:#EFF6FF;padding:2px 8px;border-radius:12px;margin-left:2px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s;margin-bottom:2px;border:none;background:none;width:100%;text-align:left}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item.active{background:#EFF6FF;color:var(--blue);font-weight:700}
.nav-item svg{width:20px;height:20px;flex-shrink:0}
.sidebar-spacer{flex:1}
.sidebar-user{padding:12px;border-top:1px solid var(--border);margin-top:8px}
.sidebar-user-name{font-size:14px;font-weight:700;color:var(--text)}
.sidebar-user-email{font-size:12px;color:var(--text3);margin-top:2px}
.main{flex:1;padding:32px;overflow-y:auto}
.page-title{font-size:24px;font-weight:800;margin-bottom:4px}
.page-sub{font-size:14px;color:var(--text2);margin-bottom:28px}

/* ── Stats Grid ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat-card{background:var(--white);border-radius:var(--radius);padding:20px;border:1px solid var(--border)}
.stat-label{font-size:12px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.stat-value{font-size:28px;font-weight:900;margin-top:4px;letter-spacing:-.5px}
.stat-sub{font-size:12px;color:var(--text3);margin-top:4px}
.stat-blue .stat-value{color:var(--blue)}
.stat-green .stat-value{color:var(--green)}
.stat-orange .stat-value{color:var(--orange)}
.stat-purple .stat-value{color:var(--purple)}

/* ── Cards / Tables ── */
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.card-header h3{font-size:16px;font-weight:700}
.card-body{padding:20px}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 16px;font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}
td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--border);color:var(--text2)}
tr:last-child td{border-bottom:none}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.badge-green{background:#F0FDF4;color:#16A34A}
.badge-blue{background:#EFF6FF;color:#2563EB}
.badge-orange{background:#FFFBEB;color:#D97706}
.badge-red{background:#FEF2F2;color:#DC2626}
.badge-gray{background:#F1F5F9;color:#64748B}

/* ── Forms ── */
.form-row{display:flex;gap:12px;margin-bottom:16px}
.form-row .field{flex:1}
select{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;color:var(--text);background:var(--bg);outline:none}
.btn-sm{padding:8px 18px;font-size:13px;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:all .15s}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--blue-dark)}
.btn-outline{background:none;border:1.5px solid var(--border);color:var(--text2)}.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-red{background:var(--red);color:#fff}

/* ── Wallet ── */
.wallet-balance{display:flex;align-items:baseline;gap:8px;margin-bottom:24px}
.wallet-amount{font-size:40px;font-weight:900;color:var(--green)}
.wallet-currency{font-size:16px;color:var(--text3);font-weight:600}
.tier-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:700;margin-left:16px}
.tier-silver{background:#F1F5F9;color:#64748B}
.tier-gold{background:#FFFBEB;color:#D97706}
.tier-platinum{background:#F5F3FF;color:#7C3AED}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100}
.modal{background:var(--white);border-radius:20px;padding:32px;width:90%;max-width:480px;max-height:80vh;overflow-y:auto}
.modal h3{font-size:20px;font-weight:800;margin-bottom:20px}
.modal-actions{display:flex;gap:10px;margin-top:24px}
.modal-actions .btn-sm{flex:1;padding:12px}

/* ── Responsive ── */
@media(max-width:768px){
  .sidebar{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .main{padding:20px}
}
