@font-face{font-family:IRANSansX;font-style:normal;font-weight:400;src:url('/assets/fonts/woff2/IRANSansXFaNum-Regular.woff2') format('woff2'),url('/assets/fonts/woff/IRANSansXFaNum-Regular.woff') format('woff')}@font-face{font-family:IRANSansX;font-style:normal;font-weight:800;src:url('/assets/fonts/woff2/IRANSansXFaNum-Bold.woff2') format('woff2'),url('/assets/fonts/woff/IRANSansXFaNum-Bold.woff') format('woff')}*{box-sizing:border-box}html,body{min-height:100%;overflow-x:hidden}body.crm-body{margin:0;font-family:IRANSansX,Tahoma,Arial,sans-serif;background:#eef5f8;color:#14213d;font-size:14px}.crm-admin{min-height:100vh;display:block}.crm-sidebar{position:fixed;inset-block:0;right:0;width:292px;background:linear-gradient(180deg,#082f49 0%,#0f766e 100%);color:#fff;padding:18px 14px;overflow-y:auto;overflow-x:hidden;z-index:1040;box-shadow:-10px 0 40px rgba(8,47,73,.22)}.brand-panel{height:74px;display:flex;align-items:center;gap:12px;padding:10px 8px 18px;border-bottom:1px solid rgba(255,255,255,.14);margin-bottom:12px}.brand-logo{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.16);font-size:24px;flex:0 0 auto}.brand-text strong{display:block;font-size:16px;font-weight:900}.brand-text small{display:block;color:rgba(255,255,255,.72);font-size:12px;margin-top:5px}.sidebar-search{position:relative;margin:12px 4px 16px}.sidebar-search i{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.65)}.sidebar-search input{width:100%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:#fff;border-radius:14px;padding:10px 38px 10px 12px;outline:0}.sidebar-search input::placeholder{color:rgba(255,255,255,.65)}.crm-menu{display:flex;flex-direction:column;gap:5px}.menu-caption{color:rgba(255,255,255,.58);font-size:11px;font-weight:900;padding:14px 10px 5px;letter-spacing:0}.crm-menu .nav-link{display:flex!important;align-items:center;gap:10px;width:100%;min-height:42px;padding:10px 12px;border-radius:14px;color:#eef9ff!important;text-decoration:none!important;background:transparent;border:1px solid transparent;transition:.18s ease;font-weight:700;white-space:normal}.crm-menu .nav-link i{width:22px;text-align:center;font-size:17px;opacity:.95;flex:0 0 22px}.crm-menu .nav-link span{line-height:1.4}.crm-menu .nav-link:hover,.crm-menu .nav-link.active{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.16);transform:translateX(-3px)}.crm-menu .nav-link.text-danger{color:#fecaca!important}.crm-main{width:auto;min-height:100vh;margin-right:292px;padding:20px 24px 34px;min-width:0}.crm-topbar{position:sticky;top:0;z-index:1020;min-height:72px;background:rgba(255,255,255,.90);backdrop-filter:blur(12px);border:1px solid #dfeaf3;border-radius:24px;box-shadow:0 16px 44px rgba(15,35,63,.08);padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:14px}.top-title{display:block;font-size:16px;font-weight:900;color:#0d223d}.top-subtitle{display:block;color:#64748b;margin-top:4px}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.content-wrap{width:100%;max-width:1440px;margin:0 auto;padding:0}.ajax-loader{position:fixed;top:92px;left:28px;z-index:1080;background:#fff;border:1px solid #dfeaf3;border-radius:999px;padding:10px 16px;display:flex;align-items:center;gap:8px;box-shadow:0 15px 45px rgba(0,0,0,.12)}.page-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:0 0 18px}.page-title h1,h1{font-size:28px;font-weight:900;margin:0;color:#0d223d;line-height:1.55}.page-title p{margin:8px 0 0;color:#64748b;line-height:1.9}.eyebrow{display:inline-flex;align-items:center;gap:6px;background:#e8fff4;color:#0f766e;border:1px solid #bceedd;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:900;margin-bottom:10px}.clinic-title h1 i{color:#0f766e;margin-left:8px}.card,.pro-card,.metric-card,.module-card{border:1px solid #dfeaf3!important;border-radius:22px!important;box-shadow:0 18px 44px rgba(28,42,68,.07)!important;background:#fff}.card-header{background:#fff;border-bottom:1px solid #eef2f7;border-radius:22px 22px 0 0!important;padding:16px 18px}.card-title{font-weight:900;color:#0d223d}.card-body{padding:18px}.metric-card{height:100%;padding:20px}.metric-card span{display:block;color:#68758b;font-weight:800}.metric-card strong{display:block;font-size:34px;line-height:1.2;margin:8px 0;color:#0f766e;font-weight:900}.metric-card small{color:#718096;line-height:1.8}.metric-card.compact strong{font-size:28px}.module-card{display:block;height:100%;padding:22px;text-decoration:none!important;color:#14213d!important;transition:.2s ease;overflow:hidden;position:relative}.module-card:before{content:"";position:absolute;inset-inline-start:0;top:0;width:5px;height:100%;background:#0f766e;opacity:.12}.module-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px rgba(28,42,68,.13)!important}.module-card i{font-size:30px;color:#0f766e}.module-card h3{font-size:18px;font-weight:900;margin:14px 0 8px}.module-card p{color:#64748b;min-height:54px;line-height:1.9}.module-card span{font-weight:900;color:#0f766e}.clinic-sync-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.clinic-sync-strip>div{background:linear-gradient(135deg,#fff,#f7fffc);border:1px solid #dbeee8;border-radius:20px;padding:16px 18px;display:flex;gap:12px;align-items:flex-start;box-shadow:0 14px 35px rgba(15,118,110,.07);min-width:0}.clinic-sync-strip i{font-size:24px;color:#0f766e;flex:0 0 auto}.clinic-sync-strip strong{display:block;color:#0d223d;font-weight:900}.clinic-sync-strip span{display:block;color:#64748b;font-size:13px;margin-top:5px;line-height:1.8}.table-responsive{border-radius:0 0 22px 22px}.table{margin:0;vertical-align:middle}.table thead th{color:#65738a;font-size:13px;background:#f8fafc;border-bottom-color:#e6edf5;font-weight:900;white-space:nowrap}.table tbody td{border-color:#eef2f7;line-height:1.8}.status-pill,.badge{display:inline-flex;align-items:center;gap:5px;padding:7px 11px;border-radius:999px;background:#e7fff7;color:#0f766e;font-size:12px;font-weight:900}.source{display:inline-flex;padding:7px 11px;border-radius:999px;background:#eef6ff;color:#1d4ed8;font-size:12px;font-weight:800}.source-bale{background:#e8fff4;color:#0f766e}.source-manual{background:#f1f5f9;color:#334155}.filters,.ajax-form{min-width:0}.filter-card{position:sticky;top:94px;z-index:10}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.stat strong{font-size:34px;color:#0f766e}.stat p,.muted{color:#64748b}.small{font-size:12px}.input,select,textarea,.form-control,.form-select{font-family:IRANSansX;border-color:#d8e4ef;border-radius:14px!important;box-shadow:none!important}.input,select,textarea{width:100%;padding:11px;background:#fff;outline:0}.form-control:focus,.form-select:focus,.input:focus,textarea:focus{border-color:#0f766e;box-shadow:0 0 0 .2rem rgba(15,118,110,.10)!important}.btn{border-radius:14px;font-weight:900}.btn-primary{background:#0f766e;border-color:#0f766e}.btn-primary:hover{background:#0b5f59;border-color:#0b5f59}.btn-icon{width:42px;height:42px;display:inline-grid;place-items:center;padding:0}.small-btn{padding:7px 11px;font-size:12px}.crm-feature-list .list-group-item{display:flex;gap:8px;align-items:flex-start;line-height:1.8;border-color:#eef2f7}.workflow-steps{display:flex;flex-direction:column;gap:12px}.workflow-step{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center}.workflow-step span{width:34px;height:34px;border-radius:12px;background:#e7fff7;color:#0f766e;display:grid;place-items:center;font-weight:900}.workflow-step p{margin:0;background:#f8fafc;border:1px solid #e6edf5;border-radius:14px;padding:10px 12px;color:#334155;line-height:1.8}.quick-actions{display:flex;flex-wrap:wrap;gap:10px}.quick-actions .btn{font-size:13px}.insight-list{display:flex;flex-direction:column;gap:10px}.insight-list>div{border:1px solid #e6edf5;background:#f8fafc;border-radius:16px;padding:12px}.insight-list strong{display:block;color:#0d223d;margin-bottom:5px}.insight-list span{color:#64748b;font-size:13px;line-height:1.8}.schema-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.schema-grid>div{display:flex;gap:8px;align-items:center;background:#f8fafc;border:1px solid #e6edf5;border-radius:14px;padding:12px;min-width:0}.schema-grid i{color:#0f766e;flex:0 0 auto}.badge.bg-primary-lt{background:#eaf2ff!important}.auth-main{min-height:100vh;display:grid;place-items:center;padding:24px}.login{width:100%;max-width:420px}.row.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.modal-content{border-radius:22px;border:0;box-shadow:0 24px 80px rgba(0,0,0,.22)}.modal-header,.modal-footer{border-color:#eef2f7}.crm-backdrop{display:none}body.ajax-busy #app-content{opacity:.65;pointer-events:none}@media(max-width:1199.98px){.crm-sidebar{transform:translateX(100%);transition:.22s ease;width:286px}.crm-admin.sidebar-open .crm-sidebar{transform:translateX(0)}.crm-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:1030}.crm-admin.sidebar-open .crm-backdrop{display:block}.crm-main{margin-right:0;padding:14px}.crm-topbar{border-radius:18px;position:sticky;top:8px}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.schema-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.clinic-sync-strip{grid-template-columns:1fr}}@media(max-width:767.98px){body.crm-body{font-size:13px}.crm-main{padding:10px}.crm-topbar{display:block;padding:12px}.top-actions{margin-top:12px}.page-title{display:block}.page-title h1,h1{font-size:22px}.grid,.schema-grid{grid-template-columns:1fr}.clinic-sync-strip>div{display:block}.clinic-sync-strip i{display:block;margin-bottom:8px}.metric-card,.module-card,.card,.pro-card{border-radius:18px!important}.table{font-size:13px}.row.form-row{grid-template-columns:1fr}.content-wrap{padding-bottom:24px}.ajax-loader{top:82px;left:12px}}

/* CRM v6 module guide and sync improvements */
.guide-box{border:1px solid rgba(13,110,253,.12);background:linear-gradient(135deg,#f8fbff,#ffffff);border-radius:18px;color:#17324d}
.guide-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:#e8f1ff;color:#0d6efd;font-size:1.3rem;flex:0 0 auto}
.sync-pills{display:flex;flex-wrap:wrap;gap:.6rem}.sync-pills span{display:inline-flex;gap:.35rem;align-items:center;padding:.55rem .8rem;border-radius:999px;background:#f5f7fb;border:1px solid #e6eaf2;font-size:.9rem;color:#2b3b52}.sync-pills i{color:#198754}.ajax-post-result:empty{display:none}.user-role-badge{border-radius:999px;padding:.35rem .65rem;background:#eef5ff;color:#0d6efd;font-size:.8rem}.audit-help{font-size:.85rem;color:#667085}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.permission-grid .item{border:1px solid #e6eaf2;border-radius:14px;padding:.75rem;background:#fff}

/* CRM v7: unified horizontal ajax filter bar
   Fixes vertical filters taking the whole page. Works for leads, patients,
   appointments, requests and any legacy .filters form. */
.filter-card{position:relative!important;top:auto!important;z-index:5;margin-bottom:18px!important;overflow:visible!important}
.filter-card .card-body{padding:18px!important}
.filter-card form.filters,
.filter-card form.ajax-form.filters{
  display:grid!important;
  grid-template-columns:minmax(260px,2.2fr) minmax(150px,1fr) minmax(150px,1fr) minmax(135px,.9fr) minmax(135px,.9fr) auto auto!important;
  gap:10px!important;
  align-items:end!important;
  width:100%!important;
  min-width:0!important;
}
.filter-card form.filters > *,
.filter-card form.ajax-form.filters > *{
  min-width:0!important;
  margin:0!important;
}
.filter-card .input,
.filter-card .form-control,
.filter-card .form-select,
.filter-card select,
.filter-card input{
  width:100%!important;
  height:46px!important;
  min-height:46px!important;
  border-radius:14px!important;
  font-size:13px!important;
}
.filter-card .btn{
  height:46px!important;
  min-width:76px!important;
  padding-inline:16px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  white-space:nowrap!important;
}
.filter-card .btn.secondary,
.filter-card a.btn.secondary{background:#f8fafc;border:1px solid #d8e4ef;color:#334155;text-decoration:none}
.filter-card .filter-actions{display:flex;gap:8px;align-items:center;justify-content:flex-start;white-space:nowrap}
@media(max-width:1399.98px){
  .filter-card form.filters,
  .filter-card form.ajax-form.filters{grid-template-columns:minmax(240px,2fr) repeat(4,minmax(120px,1fr));}
  .filter-card form.filters .btn,
  .filter-card form.ajax-form.filters .btn{width:100%}
}
@media(max-width:991.98px){
  .filter-card form.filters,
  .filter-card form.ajax-form.filters{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media(max-width:575.98px){
  .filter-card form.filters,
  .filter-card form.ajax-form.filters{grid-template-columns:1fr!important;}
  .filter-card .btn{width:100%!important;}
}
.filter-card > form.filters{padding:18px!important}

/* CRM v11: Professional Login Page */
.auth-main{
  min-height:100vh!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:32px!important;
  background:
    radial-gradient(circle at 15% 15%, rgba(15,118,110,.18), transparent 28%),
    radial-gradient(circle at 84% 20%, rgba(14,165,233,.14), transparent 30%),
    linear-gradient(135deg,#eef7fb 0%,#f8fafc 55%,#ecfeff 100%)!important;
  overflow:hidden;
}
.login-shell{
  width:min(1080px,100%);
  min-height:560px;
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);
  gap:0;
  border-radius:34px;
  overflow:hidden;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(203,213,225,.75);
  box-shadow:0 35px 90px rgba(15,35,63,.18);
  backdrop-filter:blur(18px);
  direction:rtl;
}
.login-brand-panel{
  position:relative;
  padding:52px 48px;
  color:#fff;
  background:linear-gradient(145deg,#082f49 0%,#0f766e 58%,#14b8a6 100%);
  overflow:hidden;
}
.login-brand-panel:before,
.login-brand-panel:after{
  content:"";
  position:absolute;
  border-radius:999px;
  background:rgba(255,255,255,.12);
}
.login-brand-panel:before{width:280px;height:280px;left:-80px;top:-80px;}
.login-brand-panel:after{width:220px;height:220px;right:-70px;bottom:-90px;}
.login-brand-badge{
  position:relative;
  z-index:1;
  width:76px;
  height:76px;
  display:grid;
  place-items:center;
  border-radius:26px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  font-size:38px;
  margin-bottom:28px;
}
.login-brand-content{position:relative;z-index:1;max-width:620px;}
.login-eyebrow{
  display:inline-flex;
  padding:8px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.18);
  font-weight:900;
  font-size:12px;
  margin-bottom:18px;
}
.login-brand-content h1{
  color:#fff!important;
  font-size:42px!important;
  line-height:1.45!important;
  margin:0 0 14px!important;
  font-weight:1000!important;
}
.login-brand-content p{
  color:rgba(255,255,255,.84);
  font-size:15px;
  line-height:2.05;
  margin:0 0 28px;
}
.login-feature-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:28px;
}
.login-feature-grid div{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:54px;
  padding:13px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-weight:900;
}
.login-feature-grid i{font-size:20px;opacity:.95;}
.login-card{
  width:100%;
  max-width:none!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  background:#fff;
  padding:54px 44px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.login-card-header{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:26px;
}
.login-lock{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:#e7fff7;
  color:#0f766e;
  font-size:27px;
  flex:0 0 auto;
}
.login-card h2{
  margin:0 0 5px;
  color:#0d223d;
  font-size:25px;
  font-weight:1000;
}
.login-card p{margin:0;color:#64748b;line-height:1.85;}
.login-form .form-floating>.form-control{
  height:58px!important;
  min-height:58px!important;
  padding:1.55rem .95rem .55rem!important;
  border-radius:18px!important;
  border:1px solid #d8e4ef!important;
  background:#f8fafc!important;
  text-align:right;
}
.login-form .form-floating>label{
  right:0;
  left:auto;
  color:#64748b;
  padding:1rem .95rem;
  transform-origin:100% 0;
}
.login-submit{
  height:54px;
  border-radius:18px!important;
  font-size:15px;
  display:flex!important;
  align-items:center;
  justify-content:center;
  gap:9px;
  box-shadow:0 16px 34px rgba(15,118,110,.22);
}
.login-help{
  margin-top:18px;
  padding:13px 14px;
  display:flex;
  gap:10px;
  align-items:flex-start;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #e6edf5;
  color:#64748b;
  line-height:1.8;
  font-size:12px;
}
.login-help i{color:#0f766e;font-size:17px;margin-top:2px;}
@media(max-width:991.98px){
  .auth-main{padding:18px!important;overflow:auto;}
  .login-shell{grid-template-columns:1fr;min-height:auto;border-radius:26px;}
  .login-brand-panel{padding:34px 26px;}
  .login-brand-content h1{font-size:30px!important;}
  .login-card{padding:34px 26px;}
}
@media(max-width:575.98px){
  .auth-main{padding:10px!important;align-items:flex-start!important;}
  .login-shell{border-radius:22px;}
  .login-feature-grid{grid-template-columns:1fr;}
  .login-card-header{align-items:flex-start;}
  .login-card h2{font-size:21px;}
}


/* CRM v12 patient picker and quick records */
.patient-picker{position:relative}
.patient-search-results{position:absolute;z-index:1080;inset-inline:0;top:calc(100% - 18px);background:#fff;border:1px solid rgba(15,23,42,.12);border-radius:16px;box-shadow:0 18px 45px rgba(15,23,42,.16);padding:8px;max-height:280px;overflow:auto}
.patient-result-item{width:100%;border:0;background:transparent;text-align:right;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;color:#0f172a}
.patient-result-item:hover{background:#eef6f6}
.patient-result-item span{font-size:12px;color:#64748b;direction:ltr;text-align:left}
.patient-result-empty{padding:14px;color:#64748b;text-align:center}
#quick-records-card .table td{vertical-align:middle}
