/*
Theme Name: DGM Experts Admin Portal
Theme URI: https://dgmexperts.in
Author: Ashtam Singhal — DGM Experts
Description: Complete admin portal with OTP login, role dashboards, task management, client services, project password vault.
Version: 3.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: Proprietary
Text Domain: dgm-portal
*/

/* ── DESIGN TOKENS ── */
:root {
  --p:#ff6b00; --pd:#d95a00; --pg:rgba(255,107,0,.15);
  --bg:#080808; --s1:#101010; --s2:#181818; --s3:#222;
  --bd:#2a2a2a; --txt:#eee; --mut:#666;
  --ok:#00e676; --warn:#ffd740; --err:#ff1744; --info:#40c4ff;
  --purple:#9c27b0; --pink:#e91e63;
  --r:10px; --sw:265px;
  --font:'Syne',sans-serif; --body:'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--body);background:var(--bg);color:var(--txt);min-height:100vh;-webkit-font-smoothing:antialiased;}
a{color:var(--p);text-decoration:none;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:2px;}
::-webkit-scrollbar-thumb:hover{background:var(--p);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:8px;border:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:700;transition:all .17s;text-decoration:none;white-space:nowrap;}
.btn-p{background:var(--p);color:#fff;}.btn-p:hover{background:var(--pd);color:#fff;box-shadow:0 4px 16px var(--pg);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--p);border:1.5px solid var(--p);}.btn-ghost:hover{background:var(--p);color:#fff;}
.btn-ok{background:var(--ok);color:#000;font-weight:800;}
.btn-err{background:var(--err);color:#fff;}.btn-err:hover{background:#c62828;color:#fff;}
.btn-warn{background:var(--warn);color:#000;}
.btn-info{background:var(--info);color:#000;}
.btn-purple{background:var(--purple);color:#fff;}
.btn-sm{padding:5px 13px;font-size:12px;}.btn-lg{padding:13px 28px;font-size:15px;}.btn-full{width:100%;justify-content:center;}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important;}

/* FORMS */
.fg{margin-bottom:16px;}.fl{display:block;margin-bottom:5px;font-size:11px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.6px;font-family:var(--font);}
.fc{width:100%;padding:11px 14px;background:var(--s2);border:1.5px solid var(--bd);border-radius:8px;color:var(--txt);font-family:var(--body);font-size:14px;transition:border-color .2s,box-shadow .2s;}
.fc:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px var(--pg);}
.fc::placeholder{color:#383838;}
select.fc{cursor:pointer;}textarea.fc{resize:vertical;min-height:80px;}

/* CARDS */
.card{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:20px;}
.card:hover{border-color:rgba(255,107,0,.2);}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:13px;border-bottom:1px solid var(--bd);}
.ct{font-size:14px;font-weight:800;font-family:var(--font);}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;font-family:var(--font);}
.b-ok{background:rgba(0,230,118,.12);color:var(--ok);}
.b-warn{background:rgba(255,215,64,.12);color:var(--warn);}
.b-err{background:rgba(255,23,68,.12);color:var(--err);}
.b-info{background:rgba(64,196,255,.12);color:var(--info);}
.b-p{background:var(--pg);color:var(--p);}
.b-purple{background:rgba(156,39,176,.15);color:var(--purple);}
.b-pink{background:rgba(233,30,99,.15);color:var(--pink);}

/* ALERTS */
.alert{padding:11px 15px;border-radius:8px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:9px;}
.a-ok{background:rgba(0,230,118,.08);border:1px solid rgba(0,230,118,.2);color:var(--ok);}
.a-err{background:rgba(255,23,68,.08);border:1px solid rgba(255,23,68,.2);color:var(--err);}
.a-warn{background:rgba(255,215,64,.08);border:1px solid rgba(255,215,64,.2);color:var(--warn);}
.a-info{background:rgba(64,196,255,.08);border:1px solid rgba(64,196,255,.2);color:var(--info);}

/* TABLES */
.tw{overflow-x:auto;}
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl th{padding:10px 13px;background:var(--s2);color:var(--mut);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--bd);font-family:var(--font);}
.tbl td{padding:12px 13px;border-bottom:1px solid var(--bd);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr:hover td{background:rgba(255,107,0,.03);}

/* MODALS */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:900;align-items:center;justify-content:center;backdrop-filter:blur(6px);padding:16px;}
.mo.on{display:flex;}
.mbox{background:var(--s1);border:1px solid var(--bd);border-radius:16px;padding:26px;width:100%;max-width:520px;animation:mIn .2s ease;max-height:92vh;overflow-y:auto;}
.mbox-lg{max-width:720px;}
@keyframes mIn{from{transform:translateY(20px);opacity:0;}to{transform:translateY(0);opacity:1;}}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.mt-modal{font-size:16px;font-weight:800;font-family:var(--font);}
.mc{background:var(--s2);border:1px solid var(--bd);color:var(--mut);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;}
.mc:hover{color:var(--txt);}

/* TOAST */
#toast-box{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{background:var(--s1);border-radius:9px;padding:11px 16px;min-width:250px;max-width:340px;box-shadow:0 8px 32px rgba(0,0,0,.5);animation:tIn .22s ease;font-size:13px;display:flex;align-items:center;gap:9px;pointer-events:all;border-left:3px solid var(--p);}
.toast.ok{border-color:var(--ok);}.toast.err{border-color:var(--err);}.toast.warn{border-color:var(--warn);}
@keyframes tIn{from{transform:translateX(100%);opacity:0;}to{transform:translateX(0);opacity:1;}}

/* LOADER */
.spin{display:inline-block;width:17px;height:17px;border:2px solid rgba(255,107,0,.2);border-top-color:var(--p);border-radius:50%;animation:sp .6s linear infinite;}
@keyframes sp{to{transform:rotate(360deg);}}

/* AVATAR */
.av{display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:800;font-family:var(--font);background:var(--p);color:#fff;flex-shrink:0;}
.av-xs{width:26px;height:26px;font-size:11px;}.av-sm{width:32px;height:32px;font-size:13px;}.av-md{width:40px;height:40px;font-size:16px;}.av-lg{width:56px;height:56px;font-size:22px;}

/* STAT CARD */
.sc{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:16px 18px;transition:all .2s;position:relative;overflow:hidden;}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--sc-color,var(--p));}
.sc:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);}
.sc-icon{font-size:20px;margin-bottom:10px;}
.sc-val{font-size:24px;font-weight:900;font-family:var(--font);line-height:1;margin-bottom:3px;}
.sc-lbl{font-size:11px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.sc-chg{font-size:11px;margin-top:5px;font-weight:700;}.sc-chg.up{color:var(--ok);}.sc-chg.dn{color:var(--err);}

/* PROGRESS */
.pbar{background:var(--s3);border-radius:100px;height:6px;overflow:hidden;}
.pbar-fill{height:100%;background:linear-gradient(90deg,var(--p),#ff9a00);border-radius:100px;transition:width 1s ease;}

/* UTILS */
.flex-c{display:flex;align-items:center;}.flex-bc{display:flex;align-items:center;justify-content:space-between;}.flex-cc{display:flex;align-items:center;justify-content:center;}
.g2{gap:8px;}.g3{gap:12px;}.g4{gap:16px;}
.mt2{margin-top:8px;}.mt3{margin-top:12px;}.mt4{margin-top:16px;}.mt5{margin-top:20px;}
.mb2{margin-bottom:8px;}.mb3{margin-bottom:12px;}.mb4{margin-bottom:16px;}
.muted{color:var(--mut);}.ok-c{color:var(--ok);}.err-c{color:var(--err);}.warn-c{color:var(--warn);}.p-c{color:var(--p);}
.tc{text-align:center;}.bold{font-weight:700;}.small{font-size:12px;}.wfull{width:100%;}.hidden{display:none!important;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.stats-g{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:20px;}
@media(max-width:720px){.grid2,.grid3,.grid4{grid-template-columns:1fr;}}
.divider{display:flex;align-items:center;gap:10px;color:var(--mut);font-size:12px;margin:14px 0;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--bd);}
.empty{text-align:center;padding:50px 20px;color:var(--mut);}
.empty-icon{font-size:40px;margin-bottom:12px;}.empty-title{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:6px;}

/* PWD TOGGLE */
.pwd-wrap{position:relative;}.pwd-wrap input{padding-right:42px;}
.pwd-eye{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--mut);font-size:15px;padding:3px;}
.pwd-eye:hover{color:var(--txt);}

/* OTP */
.otp-row{display:flex;gap:8px;justify-content:center;margin:14px 0;}
.otp-d{width:48px;height:52px;text-align:center;font-size:22px;font-weight:900;font-family:var(--font);background:var(--s2);border:2px solid var(--bd);border-radius:9px;color:var(--txt);transition:all .2s;}
.otp-d:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px var(--pg);}
.otp-d.filled{border-color:var(--p);}
