/**
 * Avyukt Dental CRM — Complete UI v2.0
 * Author:  Arun Vats | Super Web Development LLP
 * Bottom-nav SPA · Zero layout shift · Mobile-first
 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800;900&family=DM+Sans:wght@400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;-webkit-text-size-adjust:100%}
:root{
  --pink:#E91E8C;--pink-d:#C2185B;--pink-l:#FCE4EC;--pink-m:#F8BBD9;
  --gold:#C9A84C;--bg:#FDF0F6;--bg2:#FFF5FA;--card:#fff;
  --text:#1A0A12;--text2:#6B3A52;--text3:#B07090;--border:#F5D0E4;
  --green:#00A86B;--green-l:#E6F9F2;--red:#E53935;--red-l:#FFEBEE;
  --orange:#FF6D00;--orange-l:#FFF3E0;--blue:#1565C0;--blue-l:#E3F2FD;
  --purple:#7B1FA2;--purple-l:#F3E5F5;
  --sh:0 2px 12px rgba(233,30,140,.10);--sh-lg:0 8px 32px rgba(233,30,140,.16);
  --r:14px;--r-sm:8px;--topbar:58px;--bottomnav:64px;
  font-family:'DM Sans','Segoe UI',sans-serif;
}
/* APP SHELL */
#adcrm-app{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden;font-family:'DM Sans','Segoe UI',sans-serif;z-index:9990}
/* TOP BAR */
.adcrm-topbar{flex-shrink:0;height:var(--topbar);background:linear-gradient(135deg,var(--pink) 0%,var(--pink-d) 100%);display:flex;align-items:center;justify-content:space-between;padding:0 14px;box-shadow:0 2px 16px rgba(194,24,91,.30);position:relative;z-index:10}
.adcrm-brand{display:flex;align-items:center;gap:10px}
.adcrm-brand-icon{width:38px;height:38px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px rgba(0,0,0,.15);flex-shrink:0}
.adcrm-brand-name{color:#fff;font-size:15px;font-weight:900;line-height:1.2;font-family:'Plus Jakarta Sans',sans-serif}
.adcrm-brand-sub{color:rgba(255,255,255,.8);font-size:11px;font-weight:500}
.adcrm-topbar-right{display:flex;align-items:center;gap:7px;flex-shrink:0}
.adcrm-pill{background:rgba(255,255,255,.22);color:#fff;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700}
.adcrm-date-text{color:rgba(255,255,255,.85);font-size:11px;font-weight:600}
.adcrm-logout{background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:8px;padding:5px 9px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s;text-decoration:none;display:inline-flex;align-items:center;gap:3px}
.adcrm-logout:hover{background:rgba(255,255,255,.28);color:#fff}
/* SCROLLABLE CONTENT */
.adcrm-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}
.adcrm-content::-webkit-scrollbar{display:none}
/* BOTTOM NAV */
.adcrm-bottom-nav{flex-shrink:0;height:var(--bottomnav);background:#fff;border-top:1px solid var(--border);display:flex;box-shadow:0 -4px 20px rgba(233,30,140,.10);position:relative;z-index:10;padding-bottom:env(safe-area-inset-bottom,0)}
.adcrm-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:10px;font-weight:700;color:var(--text3);padding:4px 2px;transition:color .18s;position:relative}
.adcrm-nav-btn.active{color:var(--pink)}
.adcrm-nav-ico{width:38px;height:24px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .18s}
.adcrm-nav-btn.active .adcrm-nav-ico{background:var(--pink-l)}
.adcrm-nav-dot{position:absolute;top:5px;right:calc(50% - 16px);width:7px;height:7px;background:var(--orange);border-radius:50%;border:2px solid #fff;display:none}
.adcrm-nav-dot.on{display:block}
/* SCREENS */
.adcrm-screen{display:none;padding:12px 12px 16px;animation:fadeIn .18s ease}
.adcrm-screen.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
/* SHARED */
.sec-hd{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:900;color:var(--text);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.sec-hd-l{display:flex;align-items:center;gap:8px}
.badge{background:var(--pink);color:#fff;border-radius:20px;padding:2px 9px;font-size:11px;font-weight:800}
.badge-o{background:var(--orange)}.badge-g{background:var(--green)}
.div-lbl{font-size:11px;font-weight:800;color:var(--text3);letter-spacing:.9px;text-transform:uppercase;margin:14px 0 8px;display:flex;align-items:center;gap:8px}
.div-lbl::after{content:'';flex:1;height:1px;background:var(--border)}
.al{border-radius:var(--r-sm);padding:10px 14px;margin-bottom:10px;display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600}
.al-red{background:var(--red-l);color:var(--red);border-left:3px solid var(--red)}
.al-orange{background:var(--orange-l);color:var(--orange);border-left:3px solid var(--orange)}
.al-green{background:var(--green-l);color:var(--green);border-left:3px solid var(--green)}
.card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:14px;margin-bottom:10px}
.card-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.card-sub{font-size:11px;color:var(--text3);font-weight:500}
.chart-h{position:relative}.chart-h-180{height:180px}.chart-h-200{height:200px}.chart-h-160{height:160px}.chart-h-140{height:140px}
.pills{display:flex;gap:6px;overflow-x:auto;margin-bottom:12px;padding-bottom:2px;scrollbar-width:none}
.pills::-webkit-scrollbar{display:none}
.pill{border:1.5px solid var(--border);border-radius:20px;padding:6px 13px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:700;background:#fff;color:var(--text2);white-space:nowrap;transition:all .18s}
.pill.active{background:var(--pink);color:#fff;border-color:var(--pink)}
.search-bar{background:#fff;border-radius:var(--r);box-shadow:var(--sh);display:flex;align-items:center;gap:9px;padding:0 14px;height:46px;margin-bottom:12px;border:1.5px solid var(--border)}
.search-bar input{flex:1;border:none;outline:none;font-family:inherit;font-size:14px;font-weight:500;color:var(--text);background:none}
.search-ico{font-size:16px;color:var(--text3)}
/* DASHBOARD HERO */
.dash-hero{background:linear-gradient(135deg,var(--pink) 0%,var(--pink-d) 100%);border-radius:18px;padding:16px;margin-bottom:12px;color:#fff;position:relative;overflow:hidden}
.dash-hero::before{content:'🦷';position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:60px;opacity:.1;pointer-events:none}
.dash-hero h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:19px;font-weight:900;margin-bottom:3px}
.dash-hero p{font-size:12px;opacity:.85}
.hero-chips{display:flex;gap:7px;margin-top:11px;flex-wrap:wrap}
.hero-chip{background:rgba(255,255,255,.22);border-radius:20px;padding:5px 11px;font-size:11px;font-weight:700}
/* KPI STATS */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.stat{background:#fff;border-radius:var(--r);box-shadow:var(--sh);padding:14px 12px;position:relative;overflow:hidden}
.stat::after{content:attr(data-i);position:absolute;bottom:-4px;right:6px;font-size:36px;opacity:.10;line-height:1;pointer-events:none}
.stat-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:24px;font-weight:900;margin-bottom:2px}
.stat-l{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.stat-d{font-size:11px;font-weight:700;margin-top:5px}
.du{color:var(--green)}.dd{color:var(--red)}
.stat.c-pink{border-bottom:3px solid var(--pink)}.stat.c-orange{border-bottom:3px solid var(--orange)}.stat.c-green{border-bottom:3px solid var(--green)}.stat.c-blue{border-bottom:3px solid var(--blue)}
/* QUICK ACTIONS */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.qa{border:none;border-radius:var(--r);padding:14px 12px;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:800;display:flex;align-items:center;gap:10px;text-align:left;transition:transform .15s,box-shadow .15s}
.qa:active{transform:scale(.96)}
.qa-ico{font-size:22px;width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.25);flex-shrink:0}
.qa-txt{line-height:1.3}
.qa-txt span{font-size:10px;opacity:.75;font-weight:500;display:block;margin-top:2px}
.qa-pink{background:var(--pink);color:#fff}.qa-dark{background:#1A0A12;color:#fff}.qa-green{background:var(--green);color:#fff}.qa-gold{background:var(--gold);color:#fff}
/* APPT CARD */
.appt-card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);padding:13px;margin-bottom:9px;border-left:4px solid var(--pink);transition:box-shadow .2s}
.appt-card:hover{box-shadow:var(--sh-lg)}
.appt-card.done{border-left-color:var(--green);opacity:.78}
.appt-card.missed{border-left-color:var(--red)}
.appt-card.fu-card{border-left-color:var(--orange)}
.appt-row1{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:5px}
.appt-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:800}
.appt-sub{font-size:11px;color:var(--text3);font-weight:500;margin-bottom:8px}
.tc{border-radius:20px;padding:4px 11px;font-size:11px;font-weight:700;flex-shrink:0;background:var(--pink-l);color:var(--pink-d)}
.tc.green{background:var(--green-l);color:var(--green)}.tc.red{background:var(--red-l);color:var(--red)}.tc.orange{background:var(--orange-l);color:var(--orange)}
.tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:9px}
.tag{border-radius:6px;padding:3px 8px;font-size:11px;font-weight:700;background:var(--bg2);color:var(--text2)}
.tag-t{background:var(--blue-l);color:var(--blue)}.tag-f{background:var(--orange-l);color:var(--orange)}.tag-m{background:var(--red-l);color:var(--red)}.tag-d{background:var(--green-l);color:var(--green)}.tag-p{background:var(--pink-l);color:var(--pink-d)}
/* BUTTONS */
.btns{display:flex;gap:6px;flex-wrap:wrap}
.ab{border:none;border-radius:8px;padding:7px 12px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:4px;transition:transform .13s,opacity .13s;white-space:nowrap}
.ab:hover{opacity:.9;transform:translateY(-1px)}.ab:active{transform:scale(.94)}
.ab-wa{background:#25D366;color:#fff}.ab-call{background:var(--blue);color:#fff}.ab-done{background:var(--green);color:#fff}.ab-pay{background:var(--pink);color:#fff}
.ab-edit{background:var(--bg2);color:var(--text2);border:1.5px solid var(--border)}.ab-del{background:var(--red-l);color:var(--red)}.ab-fu{background:var(--orange);color:#fff}
.ab-sm{padding:6px 9px;font-size:11px}.ab-full{width:100%;justify-content:center;border-radius:12px;padding:13px;font-size:14px;font-weight:800}
/* PATIENT CARD */
.pat-card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);padding:13px;margin-bottom:9px}
.pat-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.pat-av{width:48px;height:48px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--pink-l),var(--pink-m));display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:900;color:var(--pink-d)}
.pat-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:800}
.pat-sub{font-size:11px;color:var(--text3);font-weight:500;margin-top:2px}
/* PAY HERO */
.pay-hero{background:linear-gradient(135deg,#1A0A12 0%,#3D0A24 100%);border-radius:18px;padding:16px;margin-bottom:12px;color:#fff}
.pay-hero-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.pay-hero-lbl{font-size:11px;opacity:.6;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.pay-hero-amt{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:900;color:var(--gold)}
.pay-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.p3{background:rgba(255,255,255,.1);border-radius:10px;padding:10px;text-align:center}
.p3-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:900}
.p3-l{font-size:10px;opacity:.55;font-weight:600;text-transform:uppercase;margin-top:2px}
/* PAY CARD */
.pay-card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);padding:14px;margin-bottom:10px}
.pay-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.pay-pname{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:800}
.pay-trt{font-size:11px;color:var(--text3);margin-top:2px}
.ps{border-radius:20px;padding:4px 11px;font-size:11px;font-weight:800}
.ps-p{background:var(--orange-l);color:var(--orange)}.ps-d{background:var(--red-l);color:var(--red)}.ps-ok{background:var(--green-l);color:var(--green)}
.pay-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:10px}
.pa{text-align:center;background:var(--bg2);border-radius:8px;padding:8px 4px}
.pa-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:900}
.pa-n.tot{color:var(--text)}.pa-n.paid{color:var(--green)}.pa-n.due{color:var(--red)}
.pa-l{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;margin-top:2px;letter-spacing:.3px}
.prog-wrap{background:var(--bg);border-radius:20px;height:7px;margin-bottom:4px;overflow:hidden}
.prog{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--pink),var(--pink-d));transition:width .5s}
.prog.full{background:linear-gradient(90deg,var(--green),#00C853)}
.prog-pct{font-size:11px;font-weight:700;color:var(--text3);margin-bottom:10px}
.inst-list{border-top:1px solid var(--border);padding-top:8px}
.inst-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--bg2);font-size:12px}
.inst-row:last-child{border-bottom:none}
.inst-d{color:var(--text3);font-size:11px}
.inst-mode{background:var(--bg2);color:var(--text2);border-radius:5px;padding:2px 6px;font-size:10px;font-weight:700}
.inst-amt{font-weight:800;color:var(--green)}.inst-due{font-weight:800;color:var(--red)}
/* MONTH REPORT */
.month-rpt{background:linear-gradient(135deg,var(--gold) 0%,#7A5A1A 100%);border-radius:var(--r);padding:16px;margin-bottom:12px;color:#fff}
.mr-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:900;margin-bottom:2px}
.mr-sub{font-size:11px;opacity:.8}
.mr-amount{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:900;margin:7px 0 4px}
.mr-chips{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.mr-chip{background:rgba(255,255,255,.2);border-radius:8px;padding:6px 11px;font-size:12px;font-weight:700;flex:1;text-align:center;min-width:70px}
/* ANALYTICS HERO */
.an-hero{background:linear-gradient(135deg,var(--pink) 0%,var(--pink-d) 100%);border-radius:18px;padding:16px;margin-bottom:12px;color:#fff}
.an-month-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.an-month{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:900}
.an-arr{background:rgba(255,255,255,.2);border:none;color:#fff;border-radius:8px;width:32px;height:32px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.an-kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.an-kpi{background:rgba(255,255,255,.15);border-radius:10px;padding:12px;backdrop-filter:blur(4px)}
.an-kpi-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:900}
.an-kpi-l{font-size:11px;opacity:.75;margin-top:3px;font-weight:600}
.an-kpi-d{font-size:11px;margin-top:5px;font-weight:700}
.an-kpi-d.up{color:#A5F3C8}.an-kpi-d.dn{color:#FFCDD2}
/* MODAL */
.adcrm-overlay{display:none;position:fixed;inset:0;z-index:99999;background:rgba(0,0,0,.55);backdrop-filter:blur(3px);align-items:flex-end;justify-content:center}
.adcrm-overlay.open{display:flex}
.drawer,.adcrm-drawer{background:#fff;width:100%;max-width:560px;border-radius:20px 20px 0 0;padding:20px 16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0));max-height:88vh;overflow-y:auto;animation:slideUp .26s cubic-bezier(.4,0,.2,1);margin:0 auto;box-sizing:border-box}
.drawer::-webkit-scrollbar,.adcrm-drawer::-webkit-scrollbar{display:none}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.drw-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}
.drw-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:900;margin-bottom:16px;display:flex;align-items:center;gap:8px}
/* Form */
.fg{margin-bottom:13px}.fl{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.4px}
.fi{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px;color:var(--text);outline:none;transition:border .2s;box-sizing:border-box}
.fi:focus{border-color:var(--pink)}
textarea.fi{resize:vertical;min-height:60px}
.fi-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fs{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px;color:var(--text);outline:none;appearance:none;box-sizing:border-box}
.fs:focus{border-color:var(--pink)}
.save-btn{width:100%;background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;border:none;border-radius:12px;padding:15px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:800;cursor:pointer;margin-top:6px;box-shadow:0 4px 16px rgba(233,30,140,.28);transition:transform .15s}
.save-btn:hover{transform:translateY(-1px)}
.cancel-btn{width:100%;background:var(--bg2);color:var(--text2);border:none;border-radius:12px;padding:12px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;margin-top:7px}
.pm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:12px}
.pm-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.adcrm-pm-btn,.pm-btn{border:2px solid var(--border);border-radius:12px;padding:14px 6px 10px;text-align:center;cursor:pointer;background:#fff;font-family:inherit;font-size:13px;font-weight:800;transition:all .18s}
.adcrm-pm-btn.sel,.pm-btn.sel{border-color:var(--pink);background:var(--pink-l);color:var(--pink-d)}
.pm-ico{font-size:26px;margin-bottom:5px}
.pay-strip{background:var(--bg2);border-radius:12px;padding:12px;margin-bottom:14px}
.ps-row{display:flex;gap:8px}
.ps-col{flex:1;background:#fff;border-radius:8px;padding:9px;text-align:center}
.ps-col-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:900}
.ps-col-l{font-size:9px;color:var(--text3);font-weight:700;text-transform:uppercase;margin-top:2px}
/* EMPTY */
.empty{text-align:center;padding:44px 20px;color:var(--text3)}
.empty-ico{font-size:48px;margin-bottom:10px}
.empty p{font-size:14px;font-weight:700}
/* TOAST */
#adcrm-toast{position:fixed;bottom:calc(var(--bottomnav) + 12px);left:50%;transform:translateX(-50%) translateY(16px);background:#1A0A12;color:#fff;border-radius:12px;padding:12px 20px;font-size:13px;font-weight:700;z-index:999999;opacity:0;transition:all .28s;white-space:nowrap;box-shadow:0 6px 24px rgba(0,0,0,.28);pointer-events:none}
#adcrm-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
/* WP KILLSWITCH */
body.adcrm-fe-page{overflow:hidden !important;height:100% !important;background:#FDF0F6 !important}
body.adcrm-fe-page > *:not(#adcrm-app):not(script):not(style):not(#adcrm-toast){display:none !important}
body.adcrm-fe-page #wpadminbar{display:none !important}
html.adcrm-fe-page{margin-top:0 !important}
/* LOGIN */
#adcrm-login-wrap{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#FCE4EC 0%,#F8BBD9 45%,#FCE4EC 100%);padding:20px}
.login-card{background:#fff;border-radius:24px;padding:32px 24px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(233,30,140,.22)}
.login-logo{text-align:center;margin-bottom:26px}
.login-logo-ring{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--pink-d));display:inline-flex;align-items:center;justify-content:center;font-size:34px;margin-bottom:12px;box-shadow:0 8px 24px rgba(233,30,140,.30)}
.login-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:21px;font-weight:900;color:var(--text)}
.login-sub{font-size:13px;color:var(--text3);margin-top:4px}
.login-err{background:var(--red-l);color:var(--red);border-radius:9px;padding:10px 14px;font-size:13px;font-weight:600;margin-bottom:14px;border-left:3px solid var(--red)}
.login-field{margin-bottom:15px}
.login-lbl{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.4px}
.login-input{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:11px;padding:13px 15px;font-family:inherit;font-size:15px;color:var(--text);outline:none;transition:border .2s}
.login-input:focus{border-color:var(--pink)}
.login-btn{width:100%;background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;border:none;border-radius:13px;padding:15px;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:800;cursor:pointer;margin-top:6px;box-shadow:0 6px 20px rgba(233,30,140,.32);transition:transform .15s,box-shadow .15s}
.login-btn:hover{transform:translateY(-2px)}.login-btn:active{transform:scale(.97)}
.login-foot{text-align:center;font-size:12px;color:var(--text3);margin-top:18px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}

/* ═══════════════════════════════════════════════════════════════
   v3.0 ADDITIONS — Better forms · Labels · Payments · Real-time
═══════════════════════════════════════════════════════════════ */

/* Slide-in animation for injected cards */
@keyframes slideInNew {
  from { opacity:0; transform:translateY(-12px) scale(.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}

/* ── FORM MODAL IMPROVEMENTS ──────────────────────────────── */
.drawer {
  background: linear-gradient(180deg, #fff 0%, var(--bg2) 100%);
}
.drw-title {
  font-size: 18px;
  color: var(--pink);
  padding-bottom: 12px;
  border-bottom: 1.5px solid var(--border);
  margin-bottom: 18px;
}
.fg { position: relative; }
.fi, .fs {
  background: #fff;
  border: 1.5px solid #ecd6e8;
  transition: border-color .2s, box-shadow .2s;
}
.fi:focus, .fs:focus {
  border-color: var(--pink);
  box-shadow: 0 0 0 3px rgba(233,30,140,.08);
  background: #fff;
}
.fl {
  color: var(--pink-d);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .8px;
}
.save-btn {
  background: linear-gradient(135deg, var(--pink), #a01060);
  letter-spacing: .3px;
  font-size: 14px;
}
.cancel-btn {
  color: var(--text3);
  font-size: 13px;
  background: transparent;
  border: 1.5px solid var(--border);
}

/* ── PATIENT LABELS (replacing icons) ────────────────────── */
.pat-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 7px 0 9px;
}
.lbl {
  border-radius: 6px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.lbl-blue   { background: var(--blue-l);   color: var(--blue); }
.lbl-green  { background: var(--green-l);  color: var(--green); }
.lbl-red    { background: var(--red-l);    color: var(--red); }
.lbl-orange { background: var(--orange-l); color: var(--orange); }
.lbl-pink   { background: var(--pink-l);   color: var(--pink-d); }
.lbl-gold   { background: #FFF8E1;         color: var(--gold); }

.pat-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.pat-sub .lbl-ico { font-size: 12px; }

/* Patient card improved */
.pat-card {
  background: #fff;
  border-radius: var(--r);
  box-shadow: var(--sh);
  padding: 14px;
  margin-bottom: 9px;
  border-left: 4px solid var(--pink);
  transition: box-shadow .2s;
}
.pat-card:hover { box-shadow: var(--sh-lg); }

/* ── PAYMENT SCREEN — SIMPLIFIED ─────────────────────────── */
/* Cleaner pay card */
.pay-card {
  background: #fff;
  border-radius: var(--r);
  box-shadow: var(--sh);
  padding: 14px;
  margin-bottom: 10px;
  border-left: 4px solid var(--pink);
}
.pay-card[data-status=paid]    { border-left-color: var(--green); }
.pay-card[data-status=partial] { border-left-color: var(--orange); }
.pay-card[data-status=due]     { border-left-color: var(--red); }

.pay-status {
  border-radius: 20px;
  padding: 4px 11px;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}
.ps-paid    { background: var(--green-l);  color: var(--green); }
.ps-partial { background: var(--orange-l); color: var(--orange); }
.ps-due     { background: var(--red-l);    color: var(--red); }

/* Simple 3-column amounts */
.pa-item {
  text-align: center;
  background: var(--bg2);
  border-radius: 8px;
  padding: 8px 4px;
}
.pa-num { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 16px; font-weight: 900; }
.pa-num.total { color: var(--text); }
.pa-num.paid  { color: var(--green); }
.pa-num.due   { color: var(--red); }
.pa-lbl {
  font-size: 9px;
  font-weight: 700;
  color: var(--text3);
  text-transform: uppercase;
  margin-top: 2px;
  letter-spacing: .3px;
}

/* Progress bar */
.prog-wrap {
  background: var(--bg);
  border-radius: 20px;
  height: 6px;
  margin: 9px 0 4px;
  overflow: hidden;
}
.prog {
  height: 100%;
  border-radius: 20px;
  background: linear-gradient(90deg, var(--pink), var(--pink-d));
  transition: width .5s;
}
.prog.full { background: linear-gradient(90deg, var(--green), #00C853); }
.prog-pct  { font-size: 11px; font-weight: 700; color: var(--text3); margin-bottom: 10px; }

.btns-row { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }

/* Payment hero cleaner */
.pay-hero {
  background: linear-gradient(135deg, #1A0A12 0%, #3D0A24 100%);
  border-radius: 18px;
  padding: 16px;
  margin-bottom: 12px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.pay-hero::before {
  content: '₹';
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 72px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 900;
  opacity: .06;
  pointer-events: none;
}
.pay-hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 14px;
}
.pay-hero-lbl {
  font-size: 11px;
  opacity: .6;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 4px;
}
.pay-hero-amount, .pay-hero-amt {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 28px;
  font-weight: 900;
  color: var(--gold);
}
.pay-hero-3, .ph3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}
.ph3-item {
  background: rgba(255,255,255,.1);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
}
.ph3-n {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px;
  font-weight: 900;
}
.ph3-l {
  font-size: 10px;
  opacity: .55;
  font-weight: 600;
  text-transform: uppercase;
  margin-top: 2px;
}

/* ── FORM BACKGROUND IMPROVEMENT ─────────────────────────── */
/* Make modals look more polished with gradient handles */
.drw-handle {
  width: 40px;
  height: 4px;
  background: linear-gradient(90deg, var(--pink), var(--pink-d));
  border-radius: 2px;
  margin: 0 auto 16px;
  opacity: .4;
}

/* PM buttons in payment modal */
.pm-btn {
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 10px 6px;
  text-align: center;
  cursor: pointer;
  background: #fff;
  font-family: inherit;
  font-size: 11px;
  font-weight: 800;
  transition: all .18s;
  color: var(--text2);
}
.pm-btn.sel {
  border-color: var(--pink);
  background: var(--pink-l);
  color: var(--pink-d);
  box-shadow: 0 2px 8px rgba(233,30,140,.18);
}
.pm-ico { font-size: 20px; margin-bottom: 3px; }

/* Pay strip in modal */
.pay-strip {
  background: linear-gradient(135deg, #1A0A12, #2D0A20);
  border-radius: 12px;
  padding: 13px;
  margin-bottom: 14px;
  color: #fff;
}
.ps-row { display: flex; gap: 8px; }
.ps-col {
  flex: 1;
  background: rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 9px;
  text-align: center;
}
.ps-col-n {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px;
  font-weight: 900;
}
.ps-col-l {
  font-size: 9px;
  opacity: .6;
  font-weight: 700;
  text-transform: uppercase;
  margin-top: 2px;
}

/* ── SECTION BACKGROUNDS ──────────────────────────────────── */
/* Subtle mesh background on the whole app */
#adcrm-app {
  background:
    radial-gradient(ellipse at 10% 20%, rgba(233,30,140,.04) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 80%, rgba(194,24,91,.04) 0%, transparent 50%),
    var(--bg);
}

/* Screen padding */
.adcrm-screen {
  padding: 12px 12px 20px;
}

/* ── INSTRUCTION HISTORY (payments) ──────────────────────── */
.inst-list { border-top: 1px solid var(--border); padding-top: 8px; }
.inst-row  {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--bg2);
  font-size: 12px;
}
.inst-row:last-child { border-bottom: none; }
.inst-date  { color: var(--text3); font-size: 11px; margin-top: 1px; }
.inst-mode  { background: var(--bg2); color: var(--text2); border-radius: 5px; padding: 2px 6px; font-size: 10px; font-weight: 700; }
.inst-amt   { font-weight: 800; color: var(--green); }

/* ── SECTION HEADERS ──────────────────────────────────────── */
.sec-hd, .adcrm-sec-hd {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 13px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Appointment screen pill filter  */
.pills {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  margin-bottom: 12px;
  padding-bottom: 3px;
  scrollbar-width: none;
}
.pills::-webkit-scrollbar { display: none; }

/* adcrm-pills alias */
.adcrm-pills {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  margin-bottom: 12px;
  padding-bottom: 3px;
  scrollbar-width: none;
}
.adcrm-pills::-webkit-scrollbar { display: none; }

/* ═══════════════════════════════════════════════════════════════════════
   v3.1 — New Patient Cards · Payment Cards · PAB Button System
═══════════════════════════════════════════════════════════════════════ */

/* ── NEW PATIENT CARD ──────────────────────────────────────────────── */
.pat-card {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 14px 14px 12px;
  margin-bottom: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.05);
  border: 1.5px solid rgba(233,30,140,.08);
  transition: box-shadow .2s, transform .15s;
  overflow: visible;
}
.pat-card:active { transform: scale(.99); }

/* Left accent stripe */
.pat-card::before {
  content: '';
  position: absolute;
  left: 0; top: 12px; bottom: 12px;
  width: 4px;
  border-radius: 0 4px 4px 0;
  background: linear-gradient(180deg, var(--pink), var(--pink-d));
}

/* Top-right delete button */
.pat-del-btn {
  position: absolute;
  top: 10px; right: 10px;
  width: 26px; height: 26px;
  border-radius: 50%;
  border: none;
  background: var(--red-l);
  color: var(--red);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: inherit;
  font-weight: 700;
  transition: background .15s, transform .15s;
  padding: 0;
}
.pat-del-btn:hover { background: var(--red); color: #fff; transform: scale(1.1); }

/* Avatar */
.pat-av {
  width: 44px; height: 44px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px; font-weight: 900;
  flex-shrink: 0;
  margin-right: 11px;
}

/* Pat top row */
.pat-top {
  display: flex;
  align-items: flex-start;
  margin-bottom: 10px;
  padding-right: 24px; /* space for delete btn */
}
.pat-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px; font-weight: 800;
  color: var(--text);
  margin-bottom: 3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pat-sub {
  font-size: 12px; color: var(--text2); font-weight: 500;
  display: flex; flex-wrap: wrap; align-items: center; gap: 3px;
}
.pat-sep { color: var(--text3); margin: 0 1px; }

/* Label pills */
.pat-labels {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin-bottom: 10px;
}
.plbl {
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 11px; font-weight: 700;
  display: inline-flex; align-items: center; gap: 3px;
  letter-spacing: .1px;
}
.plbl-blue   { background: rgba(21,101,192,.1);  color: #1565C0; }
.plbl-green  { background: rgba(0,168,107,.1);   color: #00A86B; }
.plbl-red    { background: rgba(211,47,47,.1);   color: #D32F2F; }
.plbl-gold   { background: rgba(201,168,76,.15); color: #8B6914; }
.plbl-orange { background: rgba(230,81,0,.1);    color: #E65100; }

/* Action buttons — PAB system (Patient Action Buttons) */
.pat-actions { display: flex; gap: 6px; flex-wrap: wrap; }

.pab {
  border: none; border-radius: 10px;
  padding: 7px 12px;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px; font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 4px;
  transition: filter .15s, transform .1s;
  white-space: nowrap;
}
.pab:active { transform: scale(.96); }

.pab-wa   { background: #E8F5E9; color: #2E7D32; }
.pab-call { background: #E3F2FD; color: #1565C0; }
.pab-pay  { background: linear-gradient(135deg, var(--pink), #a01060); color: #fff; }
.pab-edit { background: var(--bg2); color: var(--text2); }
.pab-del  { background: var(--red-l); color: var(--red); }

.pab-wa:hover   { filter: brightness(.92); }
.pab-call:hover { filter: brightness(.92); }
.pab-pay:hover  { filter: brightness(1.08); }
.pab-edit:hover { background: var(--border); }

/* Pay actions row */
.pay-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 11px; }

/* ── NEW PAYMENT CARD ──────────────────────────────────────────────── */
.pay-card {
  background: #fff;
  border-radius: 16px;
  padding: 14px;
  margin-bottom: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.05);
  border: 1.5px solid rgba(0,0,0,.05);
  transition: box-shadow .2s;
}
.pay-card[data-status=paid]    { border-left: 4px solid var(--green); }
.pay-card[data-status=partial] { border-left: 4px solid var(--orange); }
.pay-card[data-status=due]     { border-left: 4px solid var(--red); }

/* Card header */
.pay-card-hd {
  display: flex; align-items: flex-start; gap: 10px;
  margin-bottom: 12px;
}
.pay-av {
  width: 40px; height: 40px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px; font-weight: 900;
  flex-shrink: 0;
}
.pay-pname {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px; font-weight: 800; color: var(--text);
  margin-bottom: 2px;
}
.pay-trt { font-size: 11px; color: var(--text2); font-weight: 500; }

/* Status badge */
.pay-badge {
  border-radius: 20px;
  padding: 4px 10px;
  font-size: 11px; font-weight: 800;
  flex-shrink: 0; margin-left: auto;
}
.pb-paid    { background: rgba(0,168,107,.12); color: var(--green); }
.pb-partial { background: rgba(230,81,0,.12);  color: var(--orange); }
.pb-due     { background: rgba(211,47,47,.12); color: var(--red); }

/* 3-col amounts */
.pay-3col {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 7px;
  margin-bottom: 10px;
}
.pa {
  background: var(--bg2);
  border-radius: 10px;
  padding: 9px 7px;
  text-align: center;
}
.pa-n { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 16px; font-weight: 900; }
.pa-tot  { color: var(--text); }
.pa-paid { color: var(--green); }
.pa-due  { color: var(--red); }
.pa-l { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; margin-top: 2px; letter-spacing: .3px; }

/* Progress */
.prog-wrap { background: var(--bg); border-radius: 20px; height: 7px; overflow: hidden; margin-bottom: 5px; }
.prog { height: 100%; border-radius: 20px; background: linear-gradient(90deg, var(--pink), var(--pink-d)); transition: width .5s; }
.prog.prog-full { background: linear-gradient(90deg, var(--green), #00C853); }

.pay-pct-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.prog-pct  { font-size: 11px; font-weight: 700; color: var(--text2); }
.prog-inst { font-size: 11px; color: var(--text3); }

/* Payment history details */
.pay-hist {
  border-top: 1.5px solid var(--bg2);
  padding-top: 8px;
  margin-bottom: 2px;
}
.pay-hist summary {
  font-size: 12px; font-weight: 800; color: var(--pink);
  cursor: pointer; list-style: none;
  display: flex; align-items: center; gap: 5px;
  padding: 4px 0; user-select: none;
}
.pay-hist summary::after { content: ' ▾'; font-size: 10px; }
.pay-hist[open] summary::after { content: ' ▴'; }
.pay-hist summary::-webkit-details-marker { display: none; }

.inst-list { padding-top: 8px; }
.inst-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; border-bottom: 1px solid var(--bg2);
}
.inst-row:last-child { border-bottom: none; }
.inst-num  { font-size: 12px; font-weight: 700; color: var(--text); }
.inst-d    { font-size: 11px; color: var(--text3); margin-top: 1px; }
.inst-right { display: flex; align-items: center; gap: 6px; }
.inst-mode { background: var(--bg2); color: var(--text2); border-radius: 5px; padding: 2px 6px; font-size: 10px; font-weight: 800; }
.inst-amt  { font-weight: 900; color: var(--green); font-size: 13px; }
.inst-due-row {
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(211,47,47,.08); border-radius: 8px;
  padding: 8px 10px; margin-top: 5px;
  font-weight: 800; color: var(--red); font-size: 12px;
}

/* Payment hero updates */
.pay-hero-out {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px; font-weight: 900; color: #FF8A80;
}
.p3-today { color: #A5F3C8; }
.p3-due   { color: #FFCDD2; }

/* ── ANIMATION ──────────────────────────────────────────────────────── */
@keyframes slideInNew {
  from { opacity:0; transform:translateY(-10px) scale(.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.pat-card, .pay-card { animation: slideInNew .28s ease both; }


/* ═══════════════════════════════════════════════════════════════════════
   v4.0 — Consistent card design across all screens
   REST API · Done/FU/Time-chip buttons · Unified pab system
═══════════════════════════════════════════════════════════════════════ */

/* ── Extra PAB button variants ───────────────────────────────────── */
.pab-done { background: var(--green-l); color: var(--green); }
.pab-done:hover { filter: brightness(.92); }

.pab-fu   { background: var(--orange-l); color: var(--orange); }
.pab-fu:hover { filter: brightness(.92); }

/* ── Time chip — sits top-right inside pat-top ───────────────────── */
.adcrm-time-chip {
  border-radius: 20px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
  margin-left: auto;
  white-space: nowrap;
  background: var(--bg2);
  color: var(--text2);
}
.adcrm-time-chip.chip-green  { background: var(--green-l);  color: var(--green); }
.adcrm-time-chip.chip-red    { background: var(--red-l);    color: var(--red); }
.adcrm-time-chip.chip-orange { background: var(--orange-l); color: var(--orange); }

/* ── Appointment card status overrides ───────────────────────────── */
.pat-card.appt-done   { opacity: .8; }
.pat-card.appt-missed { }

/* ── Follow-up notes box ─────────────────────────────────────────── */
.fu-notes {
  background: var(--bg2);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 12px;
  color: var(--text2);
  margin-bottom: 10px;
  line-height: 1.6;
  border-left: 3px solid var(--orange);
}

/* ── Pay entry uses pat-card base; override left border via inline style ── */
.pay-entry .pay-3col,
.pay-entry .prog-wrap,
.pay-entry .prog-pct,
.pay-entry .pay-hist { display: block; }

/* ── Payment hero outstanding number ─────────────────────────────── */
.pay-hero-out {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px; font-weight: 900; color: #FF8A80;
}
.p3-today { color: #A5F3C8; }
.p3-due   { color: #FFCDD2; }

