/* InfluXr – Global Light Theme CSS */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700;9..40,800&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
:root {
  --primary:    #7c3aed;
  --primary2:   #6d28d9;
  --primary-l:  #f5f3ff;
  --red:        #e8222a;
  --red2:       #c81c24;
  --green:      #16a34a;
  --orange:     #f97316;
  --gold:       #f59e0b;
  --blue:       #2563eb;
  --pink:       #db2777;
  --text:       #111827;
  --text2:      #374151;
  --muted:      #6b7280;
  --light:      #9ca3af;
  --border:     #e5e7eb;
  --border2:    #d1d5db;
  --bg:         #f5f5f4;
  --bg2:        #fafaf9;
  --white:      #ffffff;
  --font:       'DM Sans', sans-serif;
  --radius:     8px;
  --shadow:     0 1px 4px rgba(0,0,0,.07);
  --shadow2:    0 4px 20px rgba(0,0,0,.10);
  --shadow3:    0 8px 40px rgba(0,0,0,.12);
  --sidebar-w:  244px;
}

body { font-family:var(--font); color:var(--text); background:var(--bg); font-size:14px; line-height:1.5; }
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
button { font-family:var(--font); cursor:pointer; }

/* ── BUTTONS ─────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--radius); font-size:13px; font-weight:600; border:none; cursor:pointer; transition:all .2s; }
.btn-primary   { background:var(--primary);  color:#fff; } .btn-primary:hover   { background:var(--primary2); transform:translateY(-1px); }
.btn-red       { background:var(--red);      color:#fff; } .btn-red:hover       { background:var(--red2); }
.btn-green     { background:var(--green);    color:#fff; } .btn-green:hover     { background:#15803d; }
.btn-orange    { background:var(--orange);   color:#fff; } .btn-orange:hover    { background:#ea6800; }
.btn-ghost     { background:var(--white); color:var(--text2); border:1.5px solid var(--border2); } .btn-ghost:hover { border-color:var(--primary); color:var(--primary); }
.btn-outline   { background:transparent; color:var(--primary); border:1.5px solid var(--primary); } .btn-outline:hover { background:var(--primary-l); }
.btn-sm        { padding:5px 12px; font-size:12px; }
.btn-lg        { padding:12px 28px; font-size:15px; }
.btn-full      { width:100%; justify-content:center; }
.btn-gold      { background:linear-gradient(135deg,var(--gold),var(--orange)); color:#fff; }

/* ── BADGES ───────────────────────────────────── */
.badge { padding:3px 10px; border-radius:20px; font-size:11.5px; font-weight:700; display:inline-block; }
.badge-success   { background:#dcfce7; color:#166534; }
.badge-warning   { background:#fef9c3; color:#854d0e; }
.badge-danger    { background:#fee2e2; color:#991b1b; }
.badge-info      { background:#dbeafe; color:#1e40af; }
.badge-primary   { background:#ede9fe; color:#5b21b6; }
.badge-secondary { background:#f3f4f6; color:#374151; }
.badge-pink      { background:#fce7f3; color:#9d174d; }
.badge-orange    { background:#ffedd5; color:#9a3412; }

/* ── CARDS ────────────────────────────────────── */
.card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.card-head { padding:14px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; font-size:14px; font-weight:700; }
.card-body { padding:16px 18px; }

/* ── TABLE ────────────────────────────────────── */
.table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }
table { width:100%; border-collapse:collapse; min-width:500px; }
th { padding:10px 14px; text-align:left; font-size:11.5px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; background:var(--bg); }
td { padding:11px 14px; font-size:13px; border-bottom:1px solid var(--border); vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#fafafa; }

/* ── FORM ─────────────────────────────────────── */
.fgroup { margin-bottom:16px; }
.fgroup label { display:block; font-size:13px; font-weight:600; color:var(--text2); margin-bottom:6px; }
.fgroup input, .fgroup select, .fgroup textarea {
  width:100%; background:#f9fafb; border:1.5px solid var(--border); border-radius:var(--radius);
  padding:10px 13px; color:var(--text); font-family:var(--font); font-size:13.5px; outline:none; transition:all .2s;
}
.fgroup input:focus, .fgroup select:focus, .fgroup textarea:focus { border-color:var(--primary); background:var(--white); box-shadow:0 0 0 3px rgba(124,58,237,.08); }
.fgroup .iw { position:relative; }
.fgroup .iw i { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--muted); font-size:13px; }
.fgroup .iw input, .fgroup .iw select { padding-left:38px; }
.fgroup textarea { min-height:90px; resize:vertical; }
.row-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; }

/* ── ALERTS ───────────────────────────────────── */
.alert { padding:12px 16px; border-radius:var(--radius); margin-bottom:16px; font-size:13px; display:flex; align-items:center; gap:8px; }
.alert-error   { background:#fff0f0; border:1px solid #fca5a5; color:#b91c1c; }
.alert-success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.alert-info    { background:#eff6ff; border:1px solid #93c5fd; color:#1e40af; }
.alert-warning { background:#fefce8; border:1px solid #fde047; color:#854d0e; }

/* ── STATS CARDS ──────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(175px,1fr)); gap:14px; margin-bottom:20px; }
.stat-card { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:16px; position:relative; overflow:hidden; transition:transform .2s; }
.stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow2); }
.stat-card::after { content:''; position:absolute; bottom:-14px; right:-14px; width:55px; height:55px; border-radius:50%; opacity:.07; }
.sc1::after{background:var(--primary);} .sc2::after{background:var(--orange);} .sc3::after{background:var(--green);} .sc4::after{background:var(--gold);}
.stat-icon { font-size:1.3rem; margin-bottom:9px; }
.stat-top  { display:flex; align-items:center; justify-content:space-between; margin-bottom:9px; }
.stat-ic   { width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:16px; }
.stat-num  { font-size:1.6rem; font-weight:800; color:var(--text); margin-bottom:2px; }
.stat-lbl  { font-size:11.5px; color:var(--muted); }

/* ── SIDEBAR ──────────────────────────────────── */
.sidebar {
  width:var(--sidebar-w); background:var(--white); border-right:1px solid var(--border);
  position:fixed; top:0; left:0; height:100vh; display:flex; flex-direction:column;
  overflow-y:auto; z-index:50; transition:transform .28s ease;
}
.sb-logo { padding:16px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.sb-logo-txt { font-size:1.3rem; font-weight:800; color:var(--primary); }
.sb-logo-txt span { color:var(--text); }
.sb-role-tag { background:var(--primary-l); border:1px solid rgba(124,58,237,.2); border-radius:4px; padding:2px 8px; font-size:10.5px; font-weight:700; color:var(--primary); }
.sb-nav { flex:1; padding:10px 0; }
.sb-section { padding:10px 16px 4px; font-size:10px; font-weight:700; letter-spacing:.12em; color:var(--light); text-transform:uppercase; }
.sb-item { display:flex; align-items:center; gap:10px; padding:9px 16px; color:var(--muted); font-size:13px; font-weight:500; border-left:3px solid transparent; transition:all .2s; }
.sb-item:hover, .sb-item.active { color:var(--primary); background:var(--primary-l); border-left-color:var(--primary); }
.sb-item i { width:15px; text-align:center; font-size:12px; }
.sb-badge { margin-left:auto; background:var(--primary-l); color:var(--primary); font-size:11px; font-weight:700; padding:1px 7px; border-radius:20px; }
.sb-user { padding:14px 16px; border-top:1px solid var(--border); }
.sb-user-inner { display:flex; align-items:center; gap:9px; }
.sb-ava { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:#fff; flex-shrink:0; }
.sb-uname { font-size:13px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sb-urole  { font-size:11px; color:var(--muted); }

/* ── TOPBAR ───────────────────────────────────── */
.topbar { padding:12px 24px; background:var(--white); border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:40; gap:12px; }
.topbar-title { font-size:15px; font-weight:700; }
.topbar-right { display:flex; align-items:center; gap:10px; }

/* ── MAIN AREA ────────────────────────────────── */
.dash-body { display:flex; background:var(--bg); }
.main { margin-left:var(--sidebar-w); flex:1; min-height:100vh; }
.content { padding:22px 24px; }

/* ── MOBILE OVERLAY + HAMBURGER ──────────────── */
.sb-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:49; }
.sb-overlay.show { display:block; }
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:5px; flex-direction:column; gap:5px; flex-shrink:0; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── INFLUENCER CARD ──────────────────────────── */
.inf-card {
  background:var(--white); border:1px solid var(--border); border-radius:10px;
  overflow:hidden; cursor:pointer; transition:all .25s;
}
.inf-card:hover { box-shadow:var(--shadow2); transform:translateY(-3px); border-color:var(--border2); }
.inf-card-cover { height:80px; position:relative; }
.inf-card-avatar {
  width:68px; height:68px; border-radius:50%;
  border:3px solid var(--white);
  position:absolute; bottom:-22px; left:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; font-weight:800; color:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.inf-card-body { padding:28px 14px 14px; }
.inf-card-name { font-size:14px; font-weight:700; margin-bottom:2px; }
.inf-card-cat  { font-size:12px; color:var(--muted); margin-bottom:8px; }
.inf-card-stats { display:flex; gap:12px; margin-bottom:10px; }
.inf-stat { text-align:center; }
.inf-stat-n { font-size:13px; font-weight:700; color:var(--text); }
.inf-stat-l { font-size:10.5px; color:var(--muted); }
.inf-card-tags { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:10px; }
.inf-tag { background:var(--bg); border:1px solid var(--border); border-radius:20px; padding:2px 9px; font-size:11px; color:var(--text2); }
.inf-card-price { font-size:13px; font-weight:700; color:var(--primary); }
.inf-card-verified { color:var(--blue); font-size:13px; }

/* ── CAMPAIGN CARD ────────────────────────────── */
.camp-card { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:16px; transition:all .25s; }
.camp-card:hover { box-shadow:var(--shadow2); border-color:var(--border2); }
.camp-card-title { font-size:14px; font-weight:700; margin-bottom:4px; }
.camp-card-brand { font-size:12px; color:var(--muted); margin-bottom:10px; display:flex; align-items:center; gap:5px; }
.camp-meta { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:10px; }
.camp-meta-item { font-size:12px; color:var(--muted); display:flex; align-items:center; gap:4px; }

/* ── PLAN CARD ────────────────────────────────── */
.plan-card {
  background:var(--white); border:2px solid var(--border); border-radius:12px;
  padding:22px 20px; text-align:center; transition:all .25s; position:relative;
}
.plan-card:hover { border-color:var(--primary); box-shadow:var(--shadow2); transform:translateY(-3px); }
.plan-card.popular { border-color:var(--primary); box-shadow:0 0 0 1px var(--primary); }
.plan-popular-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--primary); color:#fff; font-size:11px; font-weight:700; padding:3px 14px; border-radius:20px; white-space:nowrap; }
.plan-name  { font-size:1rem; font-weight:800; margin-bottom:4px; }
.plan-price { font-size:2rem; font-weight:800; color:var(--primary); }
.plan-price span { font-size:14px; font-weight:400; color:var(--muted); }
.plan-features { list-style:none; text-align:left; margin:14px 0; display:flex; flex-direction:column; gap:8px; }
.plan-features li { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--text2); }
.plan-chk  { color:var(--green); font-size:13px; }
.plan-x    { color:var(--light); font-size:13px; }

/* ── FILTER TABS ──────────────────────────────── */
.filter-tabs { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:16px; }
.ftab { padding:6px 16px; border-radius:20px; background:var(--white); border:1.5px solid var(--border); color:var(--muted); font-size:12.5px; font-weight:500; cursor:pointer; transition:all .2s; }
.ftab:hover, .ftab.active { background:var(--primary-l); border-color:var(--primary); color:var(--primary); }

/* ── PROGRESS ─────────────────────────────────── */
.progress { height:6px; background:var(--border); border-radius:3px; overflow:hidden; }
.progress-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--primary),var(--blue)); }

/* ── MODAL ────────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:200; display:none; align-items:center; justify-content:center; padding:16px; }
.modal-overlay.open { display:flex; }
.modal { background:var(--white); border-radius:14px; padding:28px; width:100%; max-width:500px; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow3); }
.modal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.modal-head h3 { font-size:1.1rem; font-weight:800; }
.modal-close { background:var(--bg); border:none; width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:16px; display:flex; align-items:center; justify-content:center; color:var(--muted); }
.modal-close:hover { background:var(--border); }

/* ── RESPONSIVE ───────────────────────────────── */
@media(max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .main { margin-left:0 !important; }
  .hamburger { display:flex; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .row-2, .row-3 { grid-template-columns:1fr; }
  .topbar { padding:11px 14px; }
  .content { padding:14px 12px; }
}
@media(max-width:480px) {
  .stats-grid { grid-template-columns:1fr 1fr; }
  .content { padding:12px 10px; }
  .btn-lg { padding:11px 22px; font-size:14px; }
}
