@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  --bg:       #080814;
  --bg2:      #0f0f23;
  --card:     #12122a;
  --card2:    #1a1a38;
  --border:   rgba(255,255,255,0.07);
  --primary:  #7c3aed;
  --primary2: #6d28d9;
  --accent:   #f59e0b;
  --accent2:  #d97706;
  --success:  #10b981;
  --error:    #ef4444;
  --warning:  #f59e0b;
  --text:     #e2e8f0;
  --muted:    #64748b;
  --muted2:   #94a3b8;
}

html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--card2);border-radius:3px}

/* ---- LAYOUT ---- */
.app-wrapper{display:flex;min-height:100vh}

/* ---- SIDEBAR ---- */
.sidebar{width:260px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100;transition:.3s}
.sidebar-logo{padding:20px 16px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}
.sidebar-logo .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),#a855f7);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.sidebar-logo .logo-img{width:140px;height:140px;border-radius:12px;object-fit:contain}
.sidebar-logo .logo-text{font-size:18px;font-weight:700;background:linear-gradient(135deg,#a78bfa,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sidebar-logo .logo-sub{font-size:11px;color:var(--muted);font-weight:400;display:block;margin-top:-2px}
.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}
.nav-section{margin-bottom:24px}
.nav-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:0 12px;margin-bottom:8px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--muted2);font-size:14px;font-weight:500;text-decoration:none;transition:.2s;cursor:pointer;border:none;background:transparent;width:100%}
.nav-item:hover{background:var(--card);color:var(--text)}
.nav-item.active{background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(168,85,247,.15));color:#c4b5fd;border:1px solid rgba(124,58,237,.3)}
.nav-item svg,.nav-item .nav-icon{width:20px;height:20px;flex-shrink:0}
.sidebar-footer{padding:16px;border-top:1px solid var(--border)}
.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--card)}
.user-chip .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#a855f7);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.user-chip .info{flex:1;min-width:0}
.user-chip .uname{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .uemail{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---- MAIN ---- */
.main{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:64px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:50}
.topbar-title{font-size:20px;font-weight:700}
.topbar-actions{display:flex;align-items:center;gap:12px}
.content{padding:32px;flex:1}

/* ---- CARDS ---- */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px}
.card-sm{padding:16px}
.card-header{margin-bottom:20px}
.card-title{font-size:16px;font-weight:600;margin-bottom:4px}
.card-sub{font-size:13px;color:var(--muted)}

/* ---- STAT CARDS ---- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;position:relative;overflow:hidden;transition:.3s}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#a855f7)}
.stat-card:hover{border-color:rgba(124,58,237,.3);transform:translateY(-2px)}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.stat-value{font-size:28px;font-weight:800;margin-bottom:4px}
.stat-label{font-size:13px;color:var(--muted);margin-bottom:8px}
.stat-change{font-size:12px;font-weight:600}
.stat-change.up{color:var(--success)}
.stat-change.down{color:var(--error)}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:.2s;text-decoration:none;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--primary),#a855f7);color:#fff}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-secondary{background:var(--card2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--card);border-color:rgba(124,58,237,.4)}
.btn-accent{background:linear-gradient(135deg,var(--accent),#f97316);color:#fff}
.btn-accent:hover{opacity:.9;transform:translateY(-1px)}
.btn-danger{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.btn-danger:hover{background:rgba(239,68,68,.25)}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-lg{padding:14px 28px;font-size:16px}
.btn-icon{padding:8px;width:36px;height:36px;border-radius:8px}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ---- FORMS ---- */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--muted2);margin-bottom:8px}
.form-input,.form-select,.form-textarea{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:14px;color:var(--text);font-family:inherit;transition:.2s;outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.15)}
.form-input::placeholder{color:var(--muted)}
.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-select option{background:var(--card)}
.form-textarea{resize:vertical;min-height:100px}
.form-hint{font-size:12px;color:var(--muted);margin-top:6px}
.form-error{font-size:12px;color:var(--error);margin-top:6px}
.input-group{position:relative}
.input-group .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;line-height:0}
.input-group .input-icon svg{width:18px;height:18px;display:block}
.input-group .form-input{padding-left:44px}

/* ---- TABLES ---- */
.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}
table{width:100%;border-collapse:collapse}
thead{background:var(--bg2)}
th{padding:12px 16px;font-size:12px;font-weight:600;color:var(--muted);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border)}
td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}

/* ---- BADGES ---- */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.badge-success{background:rgba(16,185,129,.15);color:#34d399}
.badge-warning{background:rgba(245,158,11,.15);color:#fbbf24}
.badge-error{background:rgba(239,68,68,.15);color:#f87171}
.badge-primary{background:rgba(124,58,237,.2);color:#a78bfa}
.badge-gray{background:rgba(100,116,139,.15);color:var(--muted2)}

/* ---- AUTH PAGES ---- */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;position:relative;overflow:hidden}
.auth-page::before{content:'';position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 60% 40%,rgba(124,58,237,.12) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(245,158,11,.08) 0%,transparent 50%);pointer-events:none}
.auth-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:48px 40px;width:100%;max-width:440px;position:relative;z-index:1}
.auth-logo{text-align:center;margin-bottom:36px}
.auth-logo .icon{width:60px;height:60px;background:linear-gradient(135deg,var(--primary),#a855f7);border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px}
.auth-logo h1{font-size:24px;font-weight:800;background:linear-gradient(135deg,#c4b5fd,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-logo p{font-size:13px;color:var(--muted);margin-top:4px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:var(--muted);font-size:13px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ---- WIZARD ---- */
.wizard-steps{display:flex;align-items:center;gap:0;margin-bottom:36px;padding:0 8px}
.wizard-step{display:flex;align-items:center;flex:1}
.step-circle{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;transition:.3s;background:var(--bg2)}
.step-circle.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 0 20px rgba(124,58,237,.4)}
.step-circle.done{border-color:var(--success);background:var(--success);color:#fff}
.step-line{flex:1;height:2px;background:var(--border);transition:.3s;margin:0 8px}
.step-line.done{background:var(--success)}
.step-label{font-size:11px;color:var(--muted);text-align:center;margin-top:6px;font-weight:500}
.wizard-step.active .step-label{color:var(--primary)}
.wizard-step.done .step-label{color:var(--success)}

.wizard-pane{display:none}
.wizard-pane.active{display:block;animation:fadeIn .3s ease}

/* ---- UPLOAD ZONE ---- */
.upload-zone{border:2px dashed var(--border);border-radius:16px;padding:48px;text-align:center;cursor:pointer;transition:.3s;position:relative}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--primary);background:rgba(124,58,237,.05)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-icon{font-size:48px;margin-bottom:16px}
.upload-zone h3{font-size:16px;font-weight:600;margin-bottom:8px}
.upload-zone p{font-size:13px;color:var(--muted)}
.upload-preview{position:relative;display:inline-block;margin:16px auto 0}
.upload-preview img,.upload-preview video{max-width:100%;max-height:300px;border-radius:12px;object-fit:cover}
.upload-preview .remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#ef4444;border-radius:50%;border:none;color:#fff;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}

/* ---- AI PANEL ---- */
.ai-panel{background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(168,85,247,.05));border:1px solid rgba(124,58,237,.2);border-radius:16px;padding:20px;margin-top:20px}
.ai-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ai-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),#a855f7);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}
.ai-title{font-size:14px;font-weight:600;color:#c4b5fd}
.ai-score{display:inline-flex;align-items:center;gap:6px;font-size:22px;font-weight:800;color:var(--accent)}

/* ---- SUGGESTIONS ---- */
.suggestion-chip{display:inline-block;background:var(--card2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer;transition:.2s;margin:4px}
.suggestion-chip:hover{border-color:var(--primary);color:#c4b5fd;background:rgba(124,58,237,.1)}

/* ---- CHARTS placeholder ---- */
.chart-placeholder{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:12px;color:var(--muted);font-size:13px}

/* ---- TOAST ---- */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:12px;font-size:14px;font-weight:500;min-width:280px;max-width:360px;animation:slideIn .3s ease;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.toast-success{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);color:#34d399}
.toast-error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#f87171}
.toast-info{background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.3);color:#c4b5fd}
.toast-warning{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);color:#fbbf24}

/* ---- LOADING ---- */
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
.loader-overlay{position:fixed;inset:0;background:rgba(8,8,20,.8);display:flex;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(4px)}
.loader-box{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:40px;text-align:center}
.loader-big{width:56px;height:56px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}

/* ---- MODAL ---- */
.modal-backdrop{position:fixed;inset:0;background:rgba(8,8,20,.85);display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(4px);animation:fadeIn .2s ease}
.modal{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.modal-title{font-size:18px;font-weight:700}

/* ---- PROGRESS BAR ---- */
.progress{background:var(--bg2);border-radius:100px;height:6px;overflow:hidden}
.progress-bar{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--primary),#a855f7);transition:.5s}

/* ---- ANIMATIONS ---- */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.animate-pulse{animation:pulse 2s infinite}

/* ---- GLOW EFFECTS ---- */
.glow-primary{box-shadow:0 0 30px rgba(124,58,237,.2)}
.glow-accent{box-shadow:0 0 30px rgba(245,158,11,.2)}

/* ---- GRID HELPERS ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}
.text-sm{font-size:13px}.text-xs{font-size:11px}.text-muted{color:var(--muted)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-accent{color:var(--accent)}.text-primary{color:#a78bfa}
.font-bold{font-weight:700}.font-semibold{font-weight:600}
.rounded-full{border-radius:9999px}
.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .sidebar{width:220px}
  .main{margin-left:220px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .content{padding:20px}
  .auth-card{padding:32px 24px}
}

/* ---- PLAN BADGE ---- */
.plan-free{background:rgba(100,116,139,.15);color:var(--muted2)}
.plan-pro{background:linear-gradient(135deg,rgba(124,58,237,.3),rgba(168,85,247,.2));color:#c4b5fd}
.plan-agency{background:linear-gradient(135deg,rgba(245,158,11,.3),rgba(249,115,22,.2));color:#fbbf24}

/* ---- EMPTY STATE ---- */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-icon{font-size:56px;margin-bottom:16px}
.empty-state h3{font-size:18px;font-weight:600;color:var(--muted2);margin-bottom:8px}
.empty-state p{font-size:14px;margin-bottom:24px}

/* ---- CAMPAIGN CARD ---- */
.campaign-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;transition:.3s}
.campaign-card:hover{border-color:rgba(124,58,237,.3);transform:translateY(-2px)}

/* ---- TAG ---- */
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;background:var(--card2);color:var(--muted2)}

/* ---- OBJECTIVE CARD ---- */
.obj-card{background:var(--card2);border:2px solid var(--border);border-radius:14px;padding:20px;cursor:pointer;transition:.3s;text-align:center}
.obj-card:hover{border-color:var(--primary);background:rgba(124,58,237,.08)}
.obj-card.selected{border-color:var(--primary);background:rgba(124,58,237,.15);box-shadow:0 0 20px rgba(124,58,237,.2)}
.obj-card .obj-icon{font-size:32px;margin-bottom:12px}
.obj-card h4{font-size:14px;font-weight:600;margin-bottom:4px}
.obj-card p{font-size:12px;color:var(--muted)}
