/* ============================================================
   DMW CRM — Brand Stylesheet
   Digital Marketing Wings | by Abhishek Thakur
   ============================================================ */

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

:root {
  --orange: #FF6B00; --yellow: #FFD600; --pink: #E91E8C; --purple: #7B2FF7; --blue: #4285F4;
  --grad: linear-gradient(135deg, #FF6B00 0%, #FFD600 25%, #E91E8C 60%, #7B2FF7 100%);
  --grad-h: linear-gradient(135deg, #ff7c1a 0%, #ffe033 25%, #f0278e 60%, #8a3fff 100%);
  --text: #1a1a2e; --text-muted: #636E72; --border: #e8eaf0;
  --bg: #F4F6FB; --white: #FFFFFF;
  --sidebar-bg: #0f0f1a; --sidebar-w: 240px;
  --radius: 14px; --shadow: 0 2px 16px rgba(0,0,0,0.07);
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Poppins',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; font-size:14px; }
a { text-decoration:none; color:inherit; }

/* ---- LOGIN ---- */
.login-page {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:#0a0a0f; position:relative; overflow:hidden; padding:20px;
}
.bg-orb { position:fixed; border-radius:50%; filter:blur(80px); opacity:.18; animation:drift 12s ease-in-out infinite; pointer-events:none; }
.orb1{width:520px;height:520px;background:#FF6B00;top:-180px;left:-140px;animation-delay:0s}
.orb2{width:400px;height:400px;background:#E91E8C;bottom:-100px;right:-100px;animation-delay:-4s}
.orb3{width:300px;height:300px;background:#7B2FF7;top:40%;left:55%;animation-delay:-8s}
.orb4{width:250px;height:250px;background:#4285F4;bottom:10%;left:10%;animation-delay:-2s}
@keyframes drift {
  0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-20px) scale(1.05)} 66%{transform:translate(-20px,30px) scale(.97)}
}
.grid-bg {
  position:fixed; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px; pointer-events:none;
}
.login-box {
  background:rgba(255,255,255,.05); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.1); border-radius:28px; padding:48px 44px 44px;
  width:100%; max-width:440px; position:relative; z-index:10;
  animation:slideUp .7s cubic-bezier(.22,1,.36,1) both;
}
@keyframes slideUp { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
.login-logo{text-align:center;margin-bottom:10px}
.login-logo img{width:200px;height:auto;display:block;margin:0 auto 8px;filter:drop-shadow(0 0 24px rgba(233,30,140,.35));animation:glow 3s ease-in-out infinite}
@keyframes glow{0%,100%{filter:drop-shadow(0 0 20px rgba(233,30,140,.3))} 50%{filter:drop-shadow(0 0 36px rgba(123,47,247,.5))}}
.crm-label{font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.author-line{font-size:11px;color:rgba(255,255,255,.38);margin-top:2px}
.author-line span{font-weight:600;color:rgba(255,255,255,.6)}
.login-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);margin:20px 0 24px}
.login-roles{display:flex;gap:8px;justify-content:center;margin-top:20px}
.role-pill{font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;letter-spacing:.04em}
.role-pill.admin{background:rgba(255,214,0,.12);color:#FFD600;border:1px solid rgba(255,214,0,.3)}
.role-pill.emp{background:rgba(66,133,244,.12);color:#4285F4;border:1px solid rgba(66,133,244,.3)}
.role-pill.client{background:rgba(233,30,140,.12);color:#E91E8C;border:1px solid rgba(233,30,140,.3)}
.footer-note{text-align:center;margin-top:18px;font-size:11px;color:rgba(255,255,255,.22)}

/* ---- FORMS ---- */
.form-group{margin-bottom:18px}
.form-group label,.form-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px}
.login-page .form-group label{color:rgba(255,255,255,.4)}
.form-group input,.form-group select,.form-group textarea,
input[type=text],input[type=email],input[type=password],input[type=date],input[type=time],input[type=number],select,textarea {
  width:100%; padding:11px 14px; border:1px solid var(--border); border-radius:10px;
  font-size:14px; font-family:'Poppins',sans-serif; transition:all .2s; outline:none; background:var(--white); color:var(--text);
}
.login-page .form-group input,.login-page .form-group select {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); color:#fff;
}
.login-page .form-group input::placeholder{color:rgba(255,255,255,.22)}
.login-page .form-group input:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,140,.15)}
input:focus,select:focus,textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,140,.1)}
textarea{resize:vertical;min-height:90px}
.input-wrap{position:relative}
.input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:15px;color:rgba(255,255,255,.3)}
.input-wrap input{padding-left:40px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-family:'Poppins',sans-serif;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;width:100%}
.btn-primary:hover{background:var(--grad-h);transform:translateY(-1px);box-shadow:0 6px 20px rgba(233,30,140,.35)}
.btn-sm{padding:6px 14px;font-size:12px;border-radius:8px;width:auto!important}
.btn-danger{background:#ff5252;color:#fff}
.btn-danger:hover{background:#e53935}
.btn-success{background:#00c853;color:#fff}
.btn-warning{background:#FFD600;color:#333}
.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border);width:auto}
.btn-secondary:hover{background:var(--border)}
.btn-outline{background:transparent;border:1px solid var(--pink);color:var(--pink);width:auto}
.btn-outline:hover{background:var(--pink);color:#fff}
.btn-icon{width:34px;height:34px;padding:0;justify-content:center;border-radius:8px}
.btn-grad-outline{background:transparent;border:2px solid transparent;background-clip:padding-box;position:relative;color:var(--pink);width:auto}

/* ---- LAYOUT ---- */
.crm-layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid rgba(255,255,255,.06);padding:0;flex-shrink:0;position:fixed;height:100vh;overflow-y:auto;z-index:100;display:flex;flex-direction:column}
.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.07);text-align:center}
.sidebar-logo img{width:110px;display:block;margin:0 auto 8px;filter:drop-shadow(0 0 12px rgba(233,30,140,.3))}
.s-crm{font-size:9px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.s-author{font-size:10px;color:rgba(255,255,255,.28);margin-top:2px}
.sidebar-nav{flex:1;padding:12px 0}
.nav-section{margin-bottom:4px}
.nav-label{font-size:9px;font-weight:800;color:rgba(255,255,255,.2);text-transform:uppercase;letter-spacing:.12em;padding:8px 18px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 16px;font-size:12.5px;font-weight:500;color:rgba(255,255,255,.45);transition:all .15s;border-left:3px solid transparent;margin:1px 0}
.nav-item:hover{background:rgba(233,30,140,.1);color:#E91E8C;border-left-color:rgba(233,30,140,.3)}
.nav-item.active{background:rgba(233,30,140,.15);color:#E91E8C;font-weight:600;border-left-color:#E91E8C}
.nav-item i{font-size:15px;width:18px;flex-shrink:0}
.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07)}
.sidebar-user{display:flex;align-items:center;gap:9px;padding:8px}
.sidebar-user .s-name{font-size:12px;font-weight:600;color:rgba(255,255,255,.7)}
.sidebar-user .s-role{font-size:10px;color:rgba(255,255,255,.3);text-transform:capitalize}
.main-content{margin-left:var(--sidebar-w);flex:1;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--border);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;gap:16px}
.topbar h1{font-size:18px;font-weight:700;color:var(--text);font-family:'Nunito',sans-serif}
.topbar-right{display:flex;align-items:center;gap:12px}
.notif-btn{position:relative;width:36px;height:36px;border-radius:50%;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);font-size:16px;transition:all .2s}
.notif-btn:hover{border-color:var(--pink);color:var(--pink)}
.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--pink);border-radius:50%;border:2px solid #fff}
.user-chip{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:var(--bg);border:1px solid var(--border);border-radius:50px;cursor:pointer}
.user-chip .u-name{font-size:12px;font-weight:600}
.user-chip .u-role{font-size:10px;color:var(--text-muted);text-transform:capitalize}
.avatar{border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Nunito',sans-serif;flex-shrink:0;width:36px;height:36px;font-size:13px}
.page-body{padding:24px 28px}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.page-header h2{font-size:16px;font-weight:700;font-family:'Nunito',sans-serif}

/* ---- CARDS ---- */
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.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:14px;font-weight:700;font-family:'Nunito',sans-serif}
.card-body{padding:20px}

/* ---- STATS ---- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.stat-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}
.stat-card .s-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}
.stat-card .s-value{font-size:28px;font-weight:800;font-family:'Nunito',sans-serif;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-card .s-sub{font-size:11px;color:var(--text-muted);margin-top:4px}
.stat-card .s-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:32px;opacity:.1}

/* ---- TABLE ---- */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);background:#fafbfc;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}
td{padding:12px 16px;border-bottom:1px solid #f0f2f5;font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafbfc}

/* ---- BADGES ---- */
.badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;letter-spacing:.03em;display:inline-block}
.badge-success{background:rgba(0,200,83,.1);color:#00c853}
.badge-danger{background:rgba(255,82,82,.1);color:#ff5252}
.badge-warning{background:rgba(255,214,0,.15);color:#b8860b}
.badge-info{background:rgba(66,133,244,.1);color:#4285F4}
.badge-secondary{background:rgba(99,110,114,.1);color:#636E72}
.badge-admin{background:rgba(255,214,0,.15);color:#b8860b}
.badge-emp{background:rgba(66,133,244,.1);color:#4285F4}
.badge-client{background:rgba(233,30,140,.1);color:#E91E8C}

/* ---- ALERTS ---- */
.alert{padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.alert-success{background:rgba(0,200,83,.1);color:#00a040;border:1px solid rgba(0,200,83,.25)}
.alert-error{background:rgba(255,82,82,.1);color:#d32f2f;border:1px solid rgba(255,82,82,.25)}
.alert-info{background:rgba(66,133,244,.1);color:#1565c0;border:1px solid rgba(66,133,244,.25)}
.alert-warning{background:rgba(255,214,0,.15);color:#856404;border:1px solid rgba(255,214,0,.3)}

/* ---- MODAL ---- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:20px;padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-header h3{font-size:16px;font-weight:700;font-family:'Nunito',sans-serif}
.modal-close{background:none;border:none;cursor:pointer;font-size:20px;color:var(--text-muted);padding:4px;border-radius:6px}
.modal-close:hover{background:var(--bg)}
.modal-box input,.modal-box select,.modal-box textarea{background:var(--bg);border:1.5px solid var(--border);}
.modal-box input:focus,.modal-box select:focus,.modal-box textarea:focus{background:#fff;border-color:var(--pink);}

/* ---- WELCOME BANNER ---- */
.welcome-banner{background:var(--grad);border-radius:var(--radius);padding:22px 26px;margin-bottom:22px;color:#fff}
.welcome-banner h2{font-size:18px;font-weight:800;font-family:'Nunito',sans-serif;margin-bottom:4px}
.welcome-banner p{font-size:13px;opacity:.85}

/* ---- PRIORITY / STATUS COLORS ---- */
.prio-urgent{color:#ff5252;font-weight:600}
.prio-high{color:#ff9800}
.prio-medium{color:#4285F4}
.prio-low{color:#00c853}

/* ---- CALENDAR ---- */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-header{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-day-name{font-size:11px;font-weight:700;text-align:center;color:var(--text-muted);text-transform:uppercase;padding:4px}
.cal-day{min-height:90px;background:var(--white);border:1px solid var(--border);border-radius:10px;padding:6px;font-size:11px;transition:all .15s}
.cal-day:hover{border-color:var(--pink)}
.cal-day.today{border-color:var(--pink);background:rgba(233,30,140,.04)}
.cal-day.other-month{background:#fafbfc;opacity:.6}
.cal-day-num{font-size:12px;font-weight:700;color:var(--text-muted);margin-bottom:4px}
.cal-day.today .cal-day-num{background:var(--pink);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.cal-post{font-size:10px;padding:2px 5px;border-radius:4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.cal-post.posted{background:rgba(0,200,83,.15);color:#00a040}
.cal-post.plan{background:rgba(66,133,244,.12);color:#4285F4}
.cal-post.draft{background:rgba(255,214,0,.2);color:#856404}
.cal-post.refine{background:rgba(255,107,0,.15);color:#FF6B00}
.cal-post.no_progress{background:rgba(99,110,114,.1);color:#636E72}
.cal-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.cal-controls h3{font-size:16px;font-weight:700;flex:1;text-align:center;font-family:'Nunito',sans-serif}
.platform-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:3px}
.platform-instagram{background:#E91E8C}
.platform-facebook{background:#4285F4}
.platform-tiktok{background:#333}
.platform-youtube{background:#ff0000}
.platform-pinterest{background:#E60023}

/* ---- FINANCE ---- */
.fin-tabs{display:flex;gap:4px;background:var(--bg);border-radius:10px;padding:4px;margin-bottom:20px}
.fin-tab{flex:1;text-align:center;padding:8px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-muted);transition:all .2s}
.fin-tab.active{background:#fff;color:var(--pink);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.amount-positive{color:#00c853;font-weight:600}
.amount-negative{color:#ff5252;font-weight:600}

/* ---- AI TOOLS ---- */
.ai-card{background:linear-gradient(135deg,rgba(255,107,0,.06),rgba(123,47,247,.08));border:1px solid rgba(233,30,140,.2);border-radius:var(--radius);padding:20px;transition:all .2s;cursor:pointer}
.ai-card:hover{border-color:var(--pink);transform:translateY(-2px);box-shadow:0 8px 24px rgba(233,30,140,.15)}
.ai-card-icon{font-size:28px;margin-bottom:10px}
.ai-card h4{font-size:13px;font-weight:700;font-family:'Nunito',sans-serif;margin-bottom:4px}
.ai-card p{font-size:11px;color:var(--text-muted);line-height:1.5}
.ai-tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px}
.ai-output{background:#0f0f1a;border-radius:12px;padding:18px;color:rgba(255,255,255,.85);font-size:13px;line-height:1.8;min-height:120px;font-family:'Poppins',sans-serif;white-space:pre-wrap;word-break:break-word}
.ai-output.loading::after{content:'Generating...';color:rgba(233,30,140,.7);font-style:italic}
.ai-loader{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- INFLUENCER ---- */
.influencer-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:all .2s;box-shadow:var(--shadow)}
.influencer-card:hover{border-color:var(--pink);transform:translateY(-2px);box-shadow:0 8px 24px rgba(233,30,140,.1)}
.influencer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.inf-platform{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;background:rgba(233,30,140,.1);color:var(--pink)}
.inf-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.inf-stat-val{font-size:15px;font-weight:800;font-family:'Nunito',sans-serif;color:var(--text)}
.inf-stat-lab{font-size:10px;color:var(--text-muted)}

/* ---- PIPELINE ---- */
.pipeline{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}
.pipe-col{min-width:220px;background:var(--bg);border-radius:12px;padding:12px}
.pipe-col-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.pipe-count{background:rgba(233,30,140,.1);color:var(--pink);font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px}
.pipe-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;font-size:12px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.pipe-card h5{font-size:12px;font-weight:700;margin-bottom:4px}
.pipe-card .meta{color:var(--text-muted);font-size:11px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:6px}

/* ---- PROGRESS BAR ---- */
.progress{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:4px}
.progress-bar{height:100%;background:var(--grad);border-radius:3px;transition:width .4s}

/* ---- EMPTY STATE ---- */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state i{font-size:48px;opacity:.25;display:block;margin-bottom:12px}
.empty-state p{font-size:13px}

/* ---- SETUP PASSWORD PAGE ---- */
.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0f;padding:20px;overflow:hidden;position:relative}

/* ---- RESPONSIVE ---- */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);transition:transform .3s}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .page-body{padding:16px}
  .topbar{padding:12px 16px}
}
.hamburger{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text)}
@media(max-width:768px){.hamburger{display:flex}}
