/* ═══════════════════════════════════════════════════════════
   ReferFlowX — Complete Global Stylesheet
   Dark Futuristic Glassmorphism Premium SaaS UI
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

/* ─── CSS Variables ───────────────────────────────────────── */
:root {
  --bg:           #050810;
  --bg2:          #070c18;
  --bg3:          #0a0f1e;
  --surface:      rgba(255,255,255,0.038);
  --surface2:     rgba(255,255,255,0.065);
  --surface3:     rgba(255,255,255,0.10);
  --border:       rgba(255,255,255,0.08);
  --border2:      rgba(0,212,255,0.18);
  --border3:      rgba(0,212,255,0.35);

  --primary:      #00d4ff;
  --primary-dim:  rgba(0,212,255,0.12);
  --primary-glow: rgba(0,212,255,0.35);
  --secondary:    #7b5ea7;
  --secondary-dim:rgba(123,94,167,0.15);
  --accent:       #ff6b35;
  --accent2:      #00ff9f;
  --accent2-dim:  rgba(0,255,159,0.12);

  --grad1:     linear-gradient(135deg,#00d4ff 0%,#7b5ea7 100%);
  --grad2:     linear-gradient(135deg,#7b5ea7 0%,#ff6b35 100%);
  --grad3:     linear-gradient(135deg,#00d4ff 0%,#00ff9f 100%);
  --grad-btn:  linear-gradient(135deg,#00d4ff,#7b5ea7);
  --grad-pro:  linear-gradient(135deg,#00d4ff,#7b5ea7,#ff6b35);

  --text:  #eef2ff;
  --text2: #8899bb;
  --text3: #4a5a7a;

  --success: #00ff9f;
  --warning: #ffb347;
  --danger:  #ff4d6d;

  --radius:    16px;
  --radius-sm: 10px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --shadow:       0 8px 32px rgba(0,0,0,0.55);
  --shadow-glow:  0 0 40px rgba(0,212,255,0.12);
  --shadow-card:  0 4px 24px rgba(0,0,0,0.4);

  --font-head: 'Syne', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --nav-h:     72px;
  --sidebar-w: 260px;
  --transition: 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ─── Reset ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:var(--primary);text-decoration:none;transition:opacity var(--transition);}
a:hover{opacity:0.8;}
img{max-width:100%;display:block;}
button{cursor:pointer;font-family:var(--font-body);}
input,select,textarea{font-family:var(--font-body);}
ul{list-style:none;}

/* ─── Background Mesh ─────────────────────────────────────── */
.bg-mesh{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 50% at 5% 5%,  rgba(0,212,255,0.07) 0%,transparent 60%),
    radial-gradient(ellipse 60% 70% at 95% 85%, rgba(123,94,167,0.09) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 50% 50%, rgba(0,255,159,0.03) 0%,transparent 70%);
}
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0.025;
  background-image:
    linear-gradient(rgba(0,212,255,1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,212,255,1) 1px,transparent 1px);
  background-size:60px 60px;
}

/* ─── Glassmorphism Cards ─────────────────────────────────── */
.glass{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
.glass-2{
  background:var(--surface2);
  border:1px solid var(--border2);
  border-radius:var(--radius);
  backdrop-filter:blur(28px);
  -webkit-backdrop-filter:blur(28px);
  box-shadow:var(--shadow-card),var(--shadow-glow);
}
.glass-3{
  background:rgba(0,212,255,0.04);
  border:1px solid var(--border3);
  border-radius:var(--radius);
  backdrop-filter:blur(20px);
  box-shadow:0 0 30px rgba(0,212,255,0.06);
}

/* ─── Buttons ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 24px;border-radius:50px;border:none;
  font-family:var(--font-head);font-weight:600;font-size:0.9rem;
  letter-spacing:0.3px;transition:all var(--transition);
  position:relative;overflow:hidden;white-space:nowrap;cursor:pointer;
}
.btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);
  opacity:0;transition:opacity var(--transition);
}
.btn:hover::after{opacity:1;}

.btn-primary{
  background:var(--grad-btn);color:#fff;
  box-shadow:0 4px 20px rgba(0,212,255,0.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,212,255,0.5);}
.btn-primary:active{transform:translateY(0);}

.btn-outline{
  background:transparent;border:1px solid var(--border2);color:var(--primary);
}
.btn-outline:hover{background:var(--primary-dim);border-color:var(--border3);box-shadow:0 0 20px var(--primary-glow);}

.btn-ghost{
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
}
.btn-ghost:hover{background:var(--surface3);}

.btn-danger{
  background:linear-gradient(135deg,#ff4d6d,#c9184a);color:#fff;
  box-shadow:0 4px 20px rgba(255,77,109,0.3);
}
.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,77,109,0.5);}

.btn-success{
  background:linear-gradient(135deg,#00ff9f,#00b870);color:#000;
  box-shadow:0 4px 20px rgba(0,255,159,0.3);font-weight:700;
}
.btn-success:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,255,159,0.5);}

.btn-warning{
  background:linear-gradient(135deg,#ffb347,#e67e00);color:#000;font-weight:700;
}
.btn-warning:hover{transform:translateY(-2px);}

.btn-sm{padding:8px 16px;font-size:0.8rem;}
.btn-lg{padding:16px 36px;font-size:1rem;}
.btn-block{width:100%;justify-content:center;}
.btn:disabled{opacity:0.45;cursor:not-allowed;transform:none!important;box-shadow:none!important;}

/* ─── Form Elements ───────────────────────────────────────── */
.form-group{margin-bottom:20px;}
.form-label{
  display:block;margin-bottom:8px;
  font-size:0.82rem;font-weight:600;color:var(--text2);
  font-family:var(--font-head);letter-spacing:0.3px;text-transform:uppercase;
}
.form-control{
  width:100%;padding:12px 16px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);font-size:0.95rem;
  transition:all var(--transition);
}
.form-control:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(0,212,255,0.12);
  background:rgba(0,212,255,0.04);
}
.form-control::placeholder{color:var(--text3);}
.form-control:disabled{opacity:0.5;cursor:not-allowed;}
select.form-control option{background:#0a0f1e;color:var(--text);}
textarea.form-control{resize:vertical;min-height:100px;}

/* ─── Alerts ──────────────────────────────────────────────── */
.alert{
  padding:13px 16px;border-radius:var(--radius-sm);
  font-size:0.88rem;margin-bottom:16px;display:none;
  animation:fadeUp 0.3s ease;
}
.alert.show{display:block;}
.alert-error  {background:rgba(255,77,109,0.1);border:1px solid rgba(255,77,109,0.3);color:#ff8fa3;}
.alert-success{background:rgba(0,255,159,0.08);border:1px solid rgba(0,255,159,0.3);color:var(--accent2);}
.alert-warning{background:rgba(255,179,71,0.08);border:1px solid rgba(255,179,71,0.3);color:var(--warning);}
.alert-info   {background:rgba(0,212,255,0.08);border:1px solid rgba(0,212,255,0.25);color:var(--primary);}

/* ─── Badges ──────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;padding:4px 12px;
  border-radius:50px;font-size:0.72rem;font-weight:700;
  font-family:var(--font-head);letter-spacing:0.6px;text-transform:uppercase;
}
.badge-active   {background:rgba(0,255,159,0.12);color:var(--accent2);border:1px solid rgba(0,255,159,0.3);}
.badge-expiring {background:rgba(255,179,71,0.12);color:var(--warning);border:1px solid rgba(255,179,71,0.3);}
.badge-expired  {background:rgba(255,77,109,0.12);color:var(--danger);border:1px solid rgba(255,77,109,0.3);}
.badge-pending  {background:rgba(0,212,255,0.12);color:var(--primary);border:1px solid rgba(0,212,255,0.3);}
.badge-approved {background:rgba(0,255,159,0.12);color:var(--accent2);border:1px solid rgba(0,255,159,0.3);}
.badge-rejected {background:rgba(255,77,109,0.12);color:var(--danger);border:1px solid rgba(255,77,109,0.3);}
.badge-starter  {background:rgba(123,94,167,0.18);color:#c4a8ff;border:1px solid rgba(123,94,167,0.4);}
.badge-pro      {background:rgba(0,212,255,0.12);color:var(--primary);border:1px solid rgba(0,212,255,0.3);}
.badge-admin    {background:rgba(255,107,53,0.12);color:#ff8c5a;border:1px solid rgba(255,107,53,0.3);}

/* ─── Table ───────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;font-size:0.88rem;}
thead th{
  padding:12px 16px;text-align:left;
  color:var(--text2);font-family:var(--font-head);font-size:0.75rem;
  font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
tbody td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,0.04);vertical-align:middle;}
tbody tr:hover{background:rgba(255,255,255,0.025);}
tbody tr:last-child td{border-bottom:none;}

/* ─── Stat Cards ──────────────────────────────────────────── */
.stat-card{padding:24px;position:relative;overflow:hidden;}
.stat-icon{
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:14px;
}
.stat-num{
  font-family:var(--font-head);font-size:2.2rem;font-weight:800;
  background:var(--grad1);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;
}
.stat-label{color:var(--text2);font-size:0.82rem;margin-top:6px;}
.stat-change{font-size:0.78rem;margin-top:4px;color:var(--accent2);}
.stat-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,var(--primary-dim),transparent);
  pointer-events:none;
}

/* ─── Toast ───────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  background:var(--bg3);border:1px solid var(--border2);
  color:var(--text);padding:14px 20px;border-radius:var(--radius);
  backdrop-filter:blur(24px);font-size:0.9rem;
  transform:translateY(100px);opacity:0;
  transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
  max-width:360px;box-shadow:var(--shadow),var(--shadow-glow);
  pointer-events:none;
}
#toast.show{transform:translateY(0);opacity:1;pointer-events:auto;}

/* ─── Loader ──────────────────────────────────────────────── */
.loader{
  width:38px;height:38px;border-radius:50%;
  border:3px solid var(--border);
  border-top-color:var(--primary);
  animation:spin 0.75s linear infinite;
  flex-shrink:0;
}
.loader-sm{width:18px;height:18px;border-width:2px;}

.loading-screen{
  position:fixed;inset:0;z-index:9000;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:18px;
  background:var(--bg);
}
.loading-screen p{color:var(--text2);font-size:0.9rem;animation:pulse 1.5s ease infinite;}

/* ─── Modal ───────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.open{display:flex;animation:fadeIn 0.2s ease;}
.modal{
  background:var(--bg3);border:1px solid var(--border2);
  border-radius:var(--radius-lg);padding:32px;width:100%;
  max-width:500px;box-shadow:var(--shadow),var(--shadow-glow);
  animation:fadeUp 0.3s ease;max-height:90vh;overflow-y:auto;
}
.modal-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;
}
.modal-title{font-family:var(--font-head);font-size:1.2rem;font-weight:700;}
.modal-close{
  background:none;border:none;color:var(--text2);
  font-size:1.6rem;cursor:pointer;line-height:1;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border-radius:8px;transition:all var(--transition);
}
.modal-close:hover{color:var(--text);background:var(--surface3);}

/* ─── Animations ──────────────────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.5;}}
@keyframes glow-pulse{
  0%,100%{box-shadow:0 0 20px rgba(0,212,255,0.25);}
  50%{box-shadow:0 0 40px rgba(0,212,255,0.55),0 0 80px rgba(0,212,255,0.15);}
}
@keyframes shimmer{
  0%{background-position:-200% center;}
  100%{background-position:200% center;}
}
@keyframes float{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}

.animate-fade-up{animation:fadeUp 0.5s ease both;}
.animate-fade-in{animation:fadeIn 0.4s ease both;}
.animate-float{animation:float 4s ease infinite;}
.anim-delay-1{animation-delay:0.1s;}
.anim-delay-2{animation-delay:0.2s;}
.anim-delay-3{animation-delay:0.3s;}
.anim-delay-4{animation-delay:0.4s;}

.glow-pulse{animation:glow-pulse 2.5s ease infinite;}

/* ─── Gradient Text ───────────────────────────────────────── */
.grad-text{
  background:var(--grad1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.grad-text-2{
  background:var(--grad2);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.grad-text-3{
  background:var(--grad3);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ─── Section Headers ─────────────────────────────────────── */
.section-label{
  font-family:var(--font-head);font-size:0.75rem;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--primary);
  margin-bottom:12px;display:flex;align-items:center;gap:8px;
}
.section-label::before{content:'';width:24px;height:2px;background:var(--primary);border-radius:2px;}
.section-title{
  font-family:var(--font-head);font-size:2.5rem;font-weight:800;
  line-height:1.12;margin-bottom:16px;
}
.section-desc{color:var(--text2);font-size:1.05rem;max-width:560px;line-height:1.7;}

/* ─── Copy Row ────────────────────────────────────────────── */
.copy-row{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;
}
.copy-row input{flex:1;background:none;border:none;color:var(--text);font-size:0.88rem;outline:none;min-width:0;}
.copy-btn{
  background:var(--primary-dim);border:1px solid rgba(0,212,255,0.25);
  border-radius:8px;color:var(--primary);padding:6px 14px;font-size:0.78rem;
  font-weight:700;cursor:pointer;transition:all var(--transition);white-space:nowrap;
  font-family:var(--font-head);
}
.copy-btn:hover{background:rgba(0,212,255,0.22);border-color:var(--border3);}
.copy-btn.copied{background:var(--accent2-dim);color:var(--accent2);border-color:rgba(0,255,159,0.3);}

/* ─── Empty State ─────────────────────────────────────────── */
.empty-state{text-align:center;padding:60px 24px;color:var(--text2);}
.empty-state .empty-icon{font-size:3.5rem;margin-bottom:16px;opacity:0.45;}
.empty-state h3{font-family:var(--font-head);font-size:1.1rem;margin-bottom:8px;color:var(--text);}
.empty-state p{font-size:0.9rem;margin-bottom:20px;}

/* ─── Scrollbar ───────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:rgba(0,212,255,0.4);}

/* ─── Utilities ───────────────────────────────────────────── */
.flex{display:flex;}
.flex-center{display:flex;align-items:center;justify-content:center;}
.flex-between{display:flex;align-items:center;justify-content:space-between;}
.flex-wrap{flex-wrap:wrap;}
.gap-1{gap:8px;} .gap-2{gap:16px;} .gap-3{gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.mt-1{margin-top:8px;} .mt-2{margin-top:16px;} .mt-3{margin-top:24px;} .mt-4{margin-top:32px;}
.mb-1{margin-bottom:8px;} .mb-2{margin-bottom:16px;} .mb-3{margin-bottom:24px;}
.p-3{padding:20px;} .p-4{padding:28px;} .p-5{padding:36px;}
.text-center{text-align:center;}
.text-right{text-align:right;}
.text-muted{color:var(--text2);}
.text-danger{color:var(--danger);}
.text-success{color:var(--accent2);}
.text-primary{color:var(--primary);}
.text-small{font-size:0.82rem;}
.text-xs{font-size:0.75rem;}
.fw-700{font-weight:700;} .fw-800{font-weight:800;}
.w-full{width:100%;}
.hidden{display:none!important;}
.mono{font-family:'Courier New',monospace;}
hr{border:none;border-top:1px solid var(--border);margin:24px 0;}

/* ─── Nav ─────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:500;height:var(--nav-h);
  background:rgba(5,8,16,0.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 32px;
  justify-content:space-between;gap:16px;
}
.nav-brand{
  font-family:var(--font-head);font-size:1.25rem;font-weight:800;
  background:var(--grad1);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a{color:var(--text2);font-size:0.88rem;font-weight:500;transition:color var(--transition);}
.nav-links a:hover{color:var(--text);}
.nav-actions{display:flex;align-items:center;gap:10px;}
.nav-user{display:flex;align-items:center;gap:10px;}
.nav-avatar{width:34px;height:34px;border-radius:50%;border:2px solid var(--border2);object-fit:cover;}
.nav-user-name{color:var(--text2);font-size:0.88rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

@media(max-width:768px){
  .nav{padding:0 16px;}
  .nav-links{display:none;}
  .nav-user-name{display:none;}
}

/* ─── Dashboard Layout ────────────────────────────────────── */
.dash-layout{display:flex;min-height:calc(100vh - var(--nav-h));}
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:rgba(5,8,16,0.6);
  border-right:1px solid var(--border);
  padding:20px 12px;
  position:sticky;top:var(--nav-h);
  height:calc(100vh - var(--nav-h));
  overflow-y:auto;
}
.sidebar-section{
  font-family:var(--font-head);font-size:0.68rem;font-weight:700;
  letter-spacing:1.8px;text-transform:uppercase;
  color:var(--text3);padding:14px 12px 6px;
}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;}
.sidebar-nav a{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:var(--radius-sm);
  color:var(--text2);font-weight:500;font-size:0.88rem;
  transition:all var(--transition);cursor:pointer;
}
.sidebar-nav a:hover{background:var(--surface2);color:var(--text);}
.sidebar-nav a.active{
  background:var(--primary-dim);color:var(--primary);
  border:1px solid rgba(0,212,255,0.18);
}
.sidebar-nav a .icon{font-size:17px;width:22px;text-align:center;flex-shrink:0;}
.dash-main{flex:1;padding:32px;overflow-x:hidden;min-width:0;}

@media(max-width:960px){
  .dash-layout{flex-direction:column;}
  .sidebar{
    width:100%;height:auto;position:static;
    padding:8px;border-right:none;border-bottom:1px solid var(--border);
    overflow-x:auto;
  }
  .sidebar-nav{flex-direction:row;gap:2px;flex-wrap:nowrap;}
  .sidebar-nav a{padding:10px 14px;white-space:nowrap;flex-shrink:0;}
  .sidebar-section{display:none;}
  .dash-main{padding:20px 16px;}
}
@media(max-width:480px){
  .dash-main{padding:16px 12px;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .section-title{font-size:1.8rem;}
}

/* ─── Plan Banner ─────────────────────────────────────────── */
.plan-banner{
  padding:16px 20px;border-radius:var(--radius);
  margin-bottom:24px;display:flex;
  align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.plan-banner.no-plan {background:rgba(0,212,255,0.05);border:1px solid rgba(0,212,255,0.18);}
.plan-banner.active  {background:rgba(0,255,159,0.05);border:1px solid rgba(0,255,159,0.2);}
.plan-banner.expiring{background:rgba(255,179,71,0.05);border:1px solid rgba(255,179,71,0.2);}
.plan-banner.expired {background:rgba(255,77,109,0.05);border:1px solid rgba(255,77,109,0.2);}
.plan-banner-title{font-family:var(--font-head);font-weight:700;margin-bottom:2px;}
.plan-banner-sub{color:var(--text2);font-size:0.82rem;}

/* ─── Campaign Card ───────────────────────────────────────── */
.campaign-card{
  padding:24px;transition:transform var(--transition),box-shadow var(--transition);
  position:relative;overflow:hidden;
}
.campaign-card:hover{transform:translateY(-4px);box-shadow:var(--shadow),0 0 30px rgba(0,212,255,0.08);}
.campaign-card-badge{
  position:absolute;top:16px;right:16px;
  font-family:var(--font-head);font-size:0.68rem;font-weight:700;
  padding:4px 10px;border-radius:50px;
  background:var(--primary-dim);color:var(--primary);
  border:1px solid rgba(0,212,255,0.25);
}
.campaign-name{font-family:var(--font-head);font-size:1.1rem;font-weight:700;margin-bottom:4px;}
.campaign-meta{color:var(--text2);font-size:0.85rem;margin-bottom:18px;}
.campaign-stats{display:flex;gap:24px;margin-bottom:18px;}
.campaign-stat-val{font-family:var(--font-head);font-size:1.6rem;font-weight:800;color:var(--primary);line-height:1;}
.campaign-stat-label{color:var(--text2);font-size:0.75rem;margin-top:3px;}
.campaign-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ─── Watermark ───────────────────────────────────────────── */
.watermark{
  position:fixed;bottom:20px;right:-20px;z-index:0;
  font-family:var(--font-head);font-size:clamp(4rem,10vw,9rem);font-weight:800;
  color:rgba(0,212,255,0.025);letter-spacing:-3px;
  pointer-events:none;user-select:none;white-space:nowrap;
  transform:rotate(-12deg);line-height:1;
}

/* ─── Landing: Hero ───────────────────────────────────────── */
.hero-section{
  min-height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;
  padding:80px 40px;position:relative;overflow:hidden;
}
.hero-content{max-width:700px;position:relative;z-index:1;}
.hero-title{
  font-family:var(--font-head);
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:800;line-height:1.08;margin-bottom:24px;
}
.hero-sub{color:var(--text2);font-size:1.12rem;margin-bottom:36px;max-width:520px;line-height:1.75;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
.hero-metrics{display:flex;gap:36px;flex-wrap:wrap;margin-top:44px;}
.hero-metric-val{font-family:var(--font-head);font-size:2rem;font-weight:800;line-height:1;}
.hero-metric-label{color:var(--text2);font-size:0.82rem;margin-top:4px;}
.hero-glow{
  position:absolute;right:80px;top:50%;transform:translateY(-50%);
  font-family:var(--font-head);font-size:clamp(8rem,20vw,16rem);
  font-weight:800;line-height:1;pointer-events:none;
  background:var(--grad1);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  opacity:0.08;user-select:none;
}
.hero-orb{
  position:absolute;border-radius:50%;pointer-events:none;
  filter:blur(80px);opacity:0.4;
}
.hero-orb-1{width:500px;height:500px;right:-100px;top:-100px;background:radial-gradient(circle,rgba(0,212,255,0.15),transparent);}
.hero-orb-2{width:400px;height:400px;left:-80px;bottom:-80px;background:radial-gradient(circle,rgba(123,94,167,0.12),transparent);}

/* ─── Landing: Sections ───────────────────────────────────── */
.section{padding:100px 40px;}
.section-inner{max-width:1140px;margin:0 auto;}

.features-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;margin-top:60px;
}
.feature-card{padding:28px;transition:transform var(--transition);}
.feature-card:hover{transform:translateY(-6px);}
.feature-icon{font-size:2.2rem;margin-bottom:16px;}
.feature-title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;margin-bottom:8px;}
.feature-desc{color:var(--text2);font-size:0.88rem;line-height:1.7;}

.steps-row{display:flex;gap:24px;margin-top:60px;flex-wrap:wrap;justify-content:center;}
.step{text-align:center;flex:1;min-width:180px;max-width:240px;padding:0 10px;}
.step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--primary-dim);border:2px solid rgba(0,212,255,0.4);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1.2rem;font-weight:800;
  color:var(--primary);margin:0 auto 16px;
}
.step-title{font-family:var(--font-head);font-weight:700;margin-bottom:8px;}
.step-desc{color:var(--text2);font-size:0.87rem;line-height:1.65;}
.step-connector{
  display:none;
}
@media(min-width:768px){
  .steps-row{flex-wrap:nowrap;}
}

.pricing-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;max-width:820px;margin:60px auto 0;
}
.pricing-card{padding:36px;text-align:center;position:relative;}
.pricing-card.featured{border-color:var(--border3);box-shadow:0 0 50px rgba(0,212,255,0.1),var(--shadow);}
.pricing-card.featured::before{
  content:'MOST POPULAR';position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--grad-btn);color:#fff;padding:5px 20px;border-radius:50px;
  font-family:var(--font-head);font-size:0.68rem;font-weight:700;letter-spacing:1.5px;
  white-space:nowrap;
}
.pricing-price{font-family:var(--font-head);font-size:3.2rem;font-weight:800;margin:18px 0 4px;line-height:1;}
.pricing-price sup{font-size:1.4rem;vertical-align:top;margin-top:10px;}
.pricing-period{color:var(--text2);font-size:0.88rem;margin-bottom:24px;}
.pricing-features{text-align:left;margin-bottom:28px;}
.pricing-features li{
  padding:9px 0;font-size:0.9rem;border-bottom:1px solid var(--border);
  display:flex;gap:10px;align-items:center;
}
.pricing-features li:last-child{border-bottom:none;}
.pricing-check{color:var(--accent2);font-size:1rem;}

.faq-wrap{max-width:780px;margin:60px auto 0;}
.faq-item{margin-bottom:12px;}
.faq-q{
  padding:18px 22px;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border);
  cursor:pointer;font-weight:600;font-size:0.95rem;
  display:flex;justify-content:space-between;align-items:center;
  transition:all var(--transition);gap:16px;
}
.faq-q:hover{border-color:var(--border2);}
.faq-q.open{border-color:rgba(0,212,255,0.3);background:var(--primary-dim);}
.faq-q .faq-arrow{flex-shrink:0;transition:transform var(--transition);}
.faq-q.open .faq-arrow{transform:rotate(45deg);}
.faq-a{
  display:none;padding:16px 22px 20px;
  color:var(--text2);font-size:0.9rem;line-height:1.7;
  border:1px solid rgba(0,212,255,0.1);border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  background:rgba(0,212,255,0.02);
}
.faq-a.open{display:block;}

/* ─── Landing: Referral Code Input ───────────────────────── */
.refcode-section{
  max-width:580px;margin:0 auto;text-align:center;
  padding:60px 32px;
}
.refcode-card{padding:40px;}
.refcode-icon{font-size:2.5rem;margin-bottom:16px;}
.refcode-row{display:flex;gap:10px;margin-top:20px;}
.refcode-row input{flex:1;}
@media(max-width:520px){.refcode-row{flex-direction:column;}}

/* ─── Landing: Footer ─────────────────────────────────────── */
footer{
  border-top:1px solid var(--border);
  padding:44px 40px;background:rgba(5,8,16,0.8);
}
.footer-inner{
  max-width:1140px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.footer-brand{font-family:var(--font-head);font-size:1.1rem;font-weight:800;}
.footer-links{display:flex;gap:24px;flex-wrap:wrap;}
.footer-links a{color:var(--text2);font-size:0.88rem;transition:color var(--transition);}
.footer-links a:hover{color:var(--text);}
.footer-copy{color:var(--text3);font-size:0.82rem;}

/* ─── Join Page ───────────────────────────────────────────── */
.join-container{
  min-height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;
}
.join-card{width:100%;max-width:480px;padding:40px;}
.join-brand{text-align:center;margin-bottom:28px;}
.join-brand h1{font-family:var(--font-head);font-size:1.6rem;font-weight:800;margin-top:10px;}
.join-brand p{color:var(--text2);font-size:0.9rem;margin-top:6px;}
.join-invited{
  padding:13px 16px;border-radius:var(--radius-sm);
  background:rgba(0,255,159,0.06);border:1px solid rgba(0,255,159,0.2);
  color:var(--accent2);font-size:0.9rem;margin-bottom:20px;text-align:center;
}
.join-success{text-align:center;padding:10px 0;}
.join-success .success-icon{font-size:4rem;margin-bottom:16px;animation:float 3s ease infinite;}
.join-success h2{font-family:var(--font-head);font-size:1.8rem;margin-bottom:8px;}
.join-success p{color:var(--text2);margin-bottom:24px;}
.ref-display{
  background:rgba(0,212,255,0.06);border:1px solid rgba(0,212,255,0.2);
  border-radius:var(--radius);padding:20px;margin:20px 0;text-align:center;
}
.ref-display .ref-label{font-size:0.78rem;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;}
.ref-display .ref-value{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--primary);letter-spacing:3px;}
.share-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px;}

/* ─── Login Page ──────────────────────────────────────────── */
.login-container{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;padding:40px 20px;position:relative;
}
.login-card{width:100%;max-width:430px;padding:48px;text-align:center;}
.login-logo{
  font-family:var(--font-head);font-size:2.2rem;font-weight:800;
  background:var(--grad1);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;
}
.login-tagline{color:var(--text2);font-size:0.9rem;margin-bottom:36px;}
.google-btn{
  width:100%;padding:15px 20px;border-radius:50px;
  border:1px solid var(--border2);
  background:rgba(255,255,255,0.04);
  color:var(--text);font-size:0.95rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:12px;
  transition:all var(--transition);cursor:pointer;
  font-family:var(--font-head);
}
.google-btn:hover{background:rgba(255,255,255,0.08);border-color:var(--border3);box-shadow:0 0 24px rgba(0,212,255,0.1);}
.google-btn:disabled{opacity:0.5;cursor:not-allowed;}
.google-icon{width:20px;height:20px;flex-shrink:0;}
.login-divider{
  display:flex;align-items:center;gap:12px;margin:28px 0;
}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.login-divider span{color:var(--text3);font-size:0.8rem;}
.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--border);}
.login-footer p{color:var(--text3);font-size:0.8rem;line-height:1.7;}

/* ─── Payment / Billing ───────────────────────────────────── */
.plan-summary-box{
  padding:20px;border-radius:var(--radius);
  background:rgba(0,212,255,0.04);border:1px solid rgba(0,212,255,0.14);
  margin-bottom:22px;
}
.price-breakdown{}
.price-row{
  display:flex;justify-content:space-between;
  padding:9px 0;font-size:0.9rem;border-bottom:1px solid var(--border);
}
.price-row:last-child{border-bottom:none;font-weight:700;font-size:1rem;color:var(--text);}
.price-row .discount-val{color:var(--accent2);}
.upi-box{
  padding:22px;border-radius:var(--radius);
  background:rgba(255,179,71,0.04);border:1px solid rgba(255,179,71,0.2);
  text-align:center;margin-bottom:22px;
}
.upi-label{color:var(--text2);font-size:0.82rem;margin-bottom:6px;}
.upi-id{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--warning);margin:6px 0;}
.upi-name{color:var(--text3);font-size:0.8rem;margin-bottom:12px;}

/* ─── Admin Specific ──────────────────────────────────────── */
.admin-badge{
  font-size:0.65rem;background:rgba(255,77,109,0.15);
  border:1px solid rgba(255,77,109,0.35);color:var(--danger);
  padding:3px 9px;border-radius:4px;font-weight:700;
  font-family:var(--font-body);letter-spacing:0.5px;
}
.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px;}

/* ─── Responsive extras ───────────────────────────────────── */
@media(max-width:768px){
  .section{padding:60px 20px;}
  .hero-section{padding:60px 20px;}
  .hero-glow,.hero-orb{display:none;}
  .refcode-section{padding:40px 20px;}
  .login-card,.join-card{padding:32px 24px;}
  .modal{padding:24px;}
  .hide-mobile{display:none!important;}
  footer{padding:32px 20px;}
  .footer-inner{flex-direction:column;text-align:center;}
}
