/* Path: hspos/public/css/admin.css */
@import url('/assets/hspos/vendor/fonts/cairo/cairo.css');

.navbar,.web-footer,.footer,header.navbar,footer{display:none!important}

html,body{margin:0!important;padding:0!important;overflow-x:hidden!important;width:100%!important;max-width:100%!important;min-height:100vh!important}
.container,.container-fluid,.container-sm,.container-md,.container-lg,.container-xl,.container-xxl,body>.container,body>.container-fluid{margin:0!important;padding:0!important;max-width:100%!important;width:100%!important}
.web-content,.page-content-wrapper,.main-section,[data-page-container],.page_content,.wrapper,.page-wrapper,.main-wrapper,.frappe-control,.frappe-list,main,article,section{margin:0!important;padding:0!important;max-width:100%!important;width:100%!important}
.page-container,.page_content,.web-content,.main-section,.container-page,.frappe-control,body>div:not(.app),#page-index,#page-admin{margin:0!important;padding:0!important;max-width:100%!important;width:100%!important}
*{box-sizing:border-box;margin:0;padding:0}

:root{
--primary:#4F46E5;--primary-hover:#4338CA;--primary-light:rgba(79,70,229,0.10);--primary-dark:#3730A3;--primary-glow:rgba(79,70,229,0.30);
--secondary:#7C3AED;--accent:#10B981;--accent-light:rgba(16,185,129,0.10);
--gradient-primary:linear-gradient(135deg,#4F46E5 0%,#7C3AED 100%);--gradient-secondary:linear-gradient(135deg,#3B82F6 0%,#2563EB 100%);--gradient-success:linear-gradient(135deg,#10B981 0%,#059669 100%);--gradient-warning:linear-gradient(135deg,#F59E0B 0%,#D97706 100%);--gradient-danger:linear-gradient(135deg,#EF4444 0%,#DC2626 100%);--gradient-purple:linear-gradient(135deg,#7C3AED 0%,#9333EA 100%);
--sidebar-bg:linear-gradient(180deg,#312E81 0%,#3730A3 50%,#4338CA 100%);--sidebar-hover:rgba(255,255,255,0.12);--sidebar-active:rgba(255,255,255,0.18);--sidebar-text:rgba(255,255,255,0.70);--sidebar-text-active:#FFFFFF;
--bg:#F1F5F9;--bg-secondary:#E2E8F0;--bg-accent:#EEF2FF;--bg-light:#F8FAFC;
--card:#FFFFFF;--card-bg:#FFFFFF;--card-hover:#F8FAFC;
--text:#1E293B;--text-primary:#1E293B;--text-secondary:#64748B;--text-muted:#94A3B8;--muted:#94A3B8;
--border:#E2E8F0;--border-color:#E2E8F0;--border-light:#F1F5F9;--border-focus:#4F46E5;
--shadow-sm:0 1px 3px rgba(0,0,0,0.04);--shadow:0 2px 8px rgba(0,0,0,0.04);--shadow-md:0 4px 16px rgba(0,0,0,0.06);--shadow-lg:0 8px 30px rgba(0,0,0,0.08);--shadow-xl:0 16px 48px rgba(0,0,0,0.10);--shadow-glow:0 0 20px var(--primary-glow);--shadow-card:0 2px 12px rgba(0,0,0,0.04);
--success:#10B981;--success-light:rgba(16,185,129,0.10);--danger:#EF4444;--danger-light:rgba(239,68,68,0.10);--warning:#F59E0B;--warning-light:rgba(245,158,11,0.10);--info:#3B82F6;--info-light:rgba(59,130,246,0.10);
--sidebar-width:260px;--header-height:56px;
--radius:6px;--radius-sm:4px;--radius-xs:3px;--radius-lg:8px;--radius-full:9999px;
--transition:all 0.2s cubic-bezier(0.4,0,0.2,1);--transition-slow:all 0.3s cubic-bezier(0.4,0,0.2,1);--transition-fast:all 0.15s cubic-bezier(0.4,0,0.2,1);
--font-en:'Cairo',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--font-ar:'Cairo','Segoe UI',sans-serif;
}

[data-theme="dark"],.dark-theme{
--bg:#0F172A;--bg-secondary:#1E293B;--bg-accent:#1E1B4B;--bg-light:#1E293B;--card:#1E293B;--card-bg:#1E293B;--card-hover:#334155;--text:#F1F5F9;--text-primary:#F1F5F9;--text-secondary:#94A3B8;--text-muted:#64748B;--muted:#64748B;--border:#334155;--border-color:#334155;--border-light:#1E293B;--sidebar-bg:linear-gradient(180deg,#1E1B4B 0%,#312E81 100%);--primary-light:rgba(79,70,229,0.20);--success-light:rgba(16,185,129,0.15);--warning-light:rgba(245,158,11,0.15);--danger-light:rgba(239,68,68,0.15);--info-light:rgba(59,130,246,0.15);--shadow-sm:0 1px 3px rgba(0,0,0,0.3);--shadow:0 2px 8px rgba(0,0,0,0.4);--shadow-md:0 4px 16px rgba(0,0,0,0.4);--shadow-lg:0 8px 30px rgba(0,0,0,0.5);--shadow-card:0 2px 12px rgba(0,0,0,0.3);
}

[dir="rtl"],[data-direction="rtl"],html[lang="ar"],html[lang="ar-SA"],html[lang="ar-EG"],html[lang="he"],html[lang="fa"],html[lang="ur"],body.rtl,body[data-lang="ar"],.app.rtl,.app[data-direction="rtl"]{direction:rtl!important;font-family:var(--font-ar)}
[dir="rtl"] .sidebar,html[lang="ar"] .sidebar,body.rtl .sidebar,.app.rtl .sidebar{left:auto!important;right:0!important;box-shadow:-4px 0 24px rgba(49,46,129,0.2)}
[dir="rtl"] .main,html[lang="ar"] .main,body.rtl .main,.app.rtl .main{margin-left:0!important;margin-right:var(--sidebar-width)!important;width:calc(100% - var(--sidebar-width))!important;max-width:calc(100% - var(--sidebar-width))!important}
[dir="rtl"] .menu-item.active::before,html[lang="ar"] .menu-item.active::before,body.rtl .menu-item.active::before{left:auto!important;right:0!important;border-radius:3px 0 0 3px!important}
[dir="rtl"] .menu-item .arrow,html[lang="ar"] .menu-item .arrow,body.rtl .menu-item .arrow{margin-left:0!important;margin-right:auto!important}
[dir="rtl"] .menu-item.open .arrow,html[lang="ar"] .menu-item.open .arrow,body.rtl .menu-item.open .arrow{transform:rotate(-90deg)!important}
[dir="rtl"] .submenu,html[lang="ar"] .submenu,body.rtl .submenu{padding-left:0!important;padding-right:8px!important}
[dir="rtl"] .submenu-item,html[lang="ar"] .submenu-item,body.rtl .submenu-item{padding:6px 22px 6px 12px!important}
[dir="rtl"] .submenu-item::before,html[lang="ar"] .submenu-item::before,body.rtl .submenu-item::before{left:auto!important;right:8px!important}
[dir="rtl"] .header,html[lang="ar"] .header,body.rtl .header{padding:0 56px 0 20px!important}
[dir="rtl"] .header-user-info,html[lang="ar"] .header-user-info,body.rtl .header-user-info{text-align:right!important;align-items:flex-end!important}
[dir="rtl"] .header-user-btn>i,html[lang="ar"] .header-user-btn>i,body.rtl .header-user-btn>i{margin-left:0!important;margin-right:2px!important}
[dir="rtl"] .header-dropdown-menu,html[lang="ar"] .header-dropdown-menu,body.rtl .header-dropdown-menu{left:auto!important;right:0!important}
[dir="rtl"] .header-dropdown-menu-right,html[lang="ar"] .header-dropdown-menu-right,body.rtl .header-dropdown-menu-right{left:0!important;right:auto!important}
[dir="rtl"] .mobile-menu-btn,html[lang="ar"] .mobile-menu-btn,body.rtl .mobile-menu-btn{left:auto!important;right:10px!important}
[dir="rtl"] select,html[lang="ar"] select,body.rtl select{background-position:left 10px center!important;padding-left:28px!important;padding-right:12px!important}
[dir="rtl"] select.form-control,html[lang="ar"] select.form-control,body.rtl select.form-control{background-position:left 10px center!important;padding-left:30px!important;padding-right:12px!important}
[dir="rtl"] .field label .req,[dir="rtl"] .form-group label .req,html[lang="ar"] .field label .req,html[lang="ar"] .form-group label .req,body.rtl .field label .req,body.rtl .form-group label .req{margin-left:0!important;margin-right:2px!important}
[dir="rtl"] .stat-card::before,html[lang="ar"] .stat-card::before,body.rtl .stat-card::before{left:auto!important;right:0!important}
[dir="rtl"] .stat-card .currency,html[lang="ar"] .stat-card .currency,body.rtl .stat-card .currency{margin-right:0!important;margin-left:3px!important}
[dir="rtl"] table th,[dir="rtl"] table td,html[lang="ar"] table th,html[lang="ar"] table td,body.rtl table th,body.rtl table td{text-align:right!important}
[dir="rtl"] .recent-meta,[dir="rtl"] .ranking-value,html[lang="ar"] .recent-meta,html[lang="ar"] .ranking-value,body.rtl .recent-meta,body.rtl .ranking-value{text-align:left!important}
[dir="rtl"] .btn i:first-child,html[lang="ar"] .btn i:first-child,body.rtl .btn i:first-child{margin-left:6px!important;margin-right:0!important}
[dir="rtl"] .actions,html[lang="ar"] .actions,body.rtl .actions{justify-content:flex-start!important}
[dir="rtl"] #toast,html[lang="ar"] #toast,body.rtl #toast{right:auto!important;left:16px!important}
[dir="rtl"] .modal-close,html[lang="ar"] .modal-close,body.rtl .modal-close{margin-left:0!important;margin-right:auto!important}
[dir="rtl"] .settings-item .form-control-sm,[dir="rtl"] .settings-item .switch,html[lang="ar"] .settings-item .form-control-sm,html[lang="ar"] .settings-item .switch,body.rtl .settings-item .form-control-sm,body.rtl .settings-item .switch{margin-left:0!important;margin-right:42px!important}

body{font-family:var(--font-en);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
[dir="rtl"] body{font-family:var(--font-ar)}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--primary-hover)}

.app{display:flex!important;min-height:100vh!important;width:100%!important;margin:0!important;padding:0!important;position:relative!important}

.sidebar{width:var(--sidebar-width)!important;background:var(--sidebar-bg);position:fixed!important;top:0!important;left:0!important;height:100vh!important;display:flex;flex-direction:column;z-index:100!important;transition:var(--transition-slow);box-shadow:4px 0 24px rgba(49,46,129,0.2)}
.sidebar::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;pointer-events:none;opacity:0.5}
.sidebar-header{padding:16px 14px;border-bottom:1px solid rgba(255,255,255,0.08);position:relative;z-index:1}
.sidebar-logo{color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;gap:10px;text-decoration:none;letter-spacing:-0.5px}
.sidebar-logo i{width:38px;height:38px;background:rgba(255,255,255,0.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:0 4px 14px rgba(79,70,229,0.3)}
.sidebar-company{display:flex;align-items:center;gap:6px;margin-top:10px;padding:6px 10px;background:rgba(255,255,255,0.06);border-radius:var(--radius-xs);color:rgba(255,255,255,0.75);font-size:11px;font-weight:500;border:1px solid rgba(255,255,255,0.05)}
.sidebar-company i{font-size:10px;opacity:0.7}
.sidebar-company span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-menu{flex:1;padding:10px 8px;overflow-y:auto;position:relative;z-index:1}
.sidebar-footer{padding:10px 8px;border-top:1px solid rgba(255,255,255,0.08);position:relative;z-index:1}
.sidebar-user-mini{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,0.04);border-radius:var(--radius-sm);margin-bottom:8px;border:1px solid rgba(255,255,255,0.05)}
.user-avatar-mini{width:32px;height:32px;border-radius:8px;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.user-info-mini{flex:1;min-width:0}
.user-name-mini{display:block;color:#fff;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role-mini{display:flex;align-items:center;gap:4px;color:rgba(255,255,255,0.55);font-size:10px}
.user-role-mini::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}

.menu-item{display:flex;align-items:center;gap:8px;padding:9px 12px;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-sm);margin-bottom:2px;cursor:pointer;transition:var(--transition);font-size:13px;font-weight:500;position:relative}
.menu-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}
.menu-item.active{background:var(--sidebar-active);color:var(--sidebar-text-active)}
.menu-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--gradient-primary);border-radius:0 3px 3px 0;box-shadow:0 0 8px var(--primary-glow)}
.menu-item i{width:18px;text-align:center;font-size:14px;opacity:0.85}
.menu-item:hover i{opacity:1}
.menu-item .arrow{font-size:9px;margin-left:auto;transition:transform 0.25s ease;opacity:0.6}
.menu-item.open .arrow{transform:rotate(90deg)}

.submenu{display:none;padding-left:8px;margin-top:2px;margin-bottom:4px}
.submenu.open{display:block;animation:submenuSlide 0.25s ease}
.submenu-item{display:flex;align-items:center;gap:6px;padding:6px 12px 6px 22px;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-xs);margin-bottom:1px;cursor:pointer;font-size:12px;font-weight:400;transition:var(--transition);position:relative}
.submenu-item::before{content:'';position:absolute;left:8px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--sidebar-text);opacity:0.4;transition:var(--transition)}
.submenu-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}
.submenu-item:hover::before{opacity:1;background:var(--primary);box-shadow:0 0 4px var(--primary-glow)}
.submenu-item.active{color:var(--sidebar-text-active);background:var(--sidebar-active)}
.submenu-item.active::before{opacity:1;background:var(--primary);box-shadow:0 0 6px var(--primary-glow)}

.logout-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;color:#FCA5A5;text-decoration:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:12px;font-weight:500;background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.1)}
.logout-btn:hover{background:rgba(239,68,68,0.15);color:#FEE2E2;border-color:rgba(239,68,68,0.2)}
.logout-btn i{width:16px;text-align:center}

.main{flex:1!important;margin-left:var(--sidebar-width)!important;margin-right:0!important;width:calc(100% - var(--sidebar-width))!important;max-width:calc(100% - var(--sidebar-width))!important;min-height:100vh!important;padding:0!important;background:var(--bg);overflow-x:hidden;position:relative}
html:not([dir="rtl"]) .main,body:not([dir="rtl"]) .main{margin-left:var(--sidebar-width)!important;margin-right:0!important}
html:not([dir="rtl"]) .sidebar,body:not([dir="rtl"]) .sidebar{left:0!important;right:auto!important}

.header{background:linear-gradient(135deg,#4F46E5,#7C3AED);border-bottom:none;padding:0 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;height:var(--header-height);box-shadow:0 2px 10px rgba(79,70,229,0.2);backdrop-filter:blur(10px)}
[data-theme="dark"] .header{background:linear-gradient(135deg,#3730A3,#6D28D9)}
.header-left{display:flex;align-items:center;gap:12px}
.header-title{font-size:17px;font-weight:700;margin:0;color:#FFFFFF;letter-spacing:-0.3px}
.header-right{display:flex;align-items:center;gap:8px}
.header-btn{width:36px;height:36px;border:none;background:rgba(255,255,255,0.18);border-radius:var(--radius-sm);color:#FFFFFF;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--transition);position:relative}
.header-btn:hover{background:rgba(255,255,255,0.30);color:#FFFFFF;transform:translateY(-1px)}
.header-btn-primary{background:rgba(255,255,255,0.25);color:#fff;box-shadow:none}
.header-btn-primary:hover{transform:translateY(-2px) scale(1.02);background:rgba(255,255,255,0.35);color:#fff}
.notification-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;padding:0 4px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid rgba(79,70,229,0.8);animation:badgePulse 2s infinite}
.header-user-btn{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:1px solid rgba(255,255,255,0.25);background:rgba(255,255,255,0.12);border-radius:var(--radius);cursor:pointer;transition:var(--transition)}
.header-user-btn:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.4);transform:translateY(-1px)}
.header-avatar{width:30px;height:30px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.25);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.header-user-info{display:flex;flex-direction:column;align-items:flex-start}
.header-user-name{font-size:12px;font-weight:600;color:#FFFFFF;line-height:1.2}
.header-user-company{font-size:10px;color:rgba(255,255,255,0.75);line-height:1.2}
.header-user-btn>i{font-size:9px;color:rgba(255,255,255,0.75);margin-left:4px;transition:transform 0.2s}

.header-dropdown{position:relative}
.header-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px;display:none;z-index:1000;animation:dropdownFadeIn 0.2s ease}
.header-dropdown-menu.show{display:block}
.header-dropdown-menu-right{left:auto;right:0;min-width:220px}
.dropdown-header{display:flex;align-items:center;gap:10px;padding:10px;margin-bottom:4px;background:var(--bg-secondary);border-radius:var(--radius-sm)}
.dropdown-user-avatar{width:38px;height:38px;border-radius:10px;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.dropdown-user-details{flex:1;min-width:0}
.dropdown-user-name{display:block;font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dropdown-user-email{display:block;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dropdown-divider{height:1px;background:var(--border);margin:4px 0}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 10px;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-xs);font-size:12px;font-weight:500;transition:var(--transition-fast);cursor:pointer}
.dropdown-item:hover{background:var(--bg-secondary);color:var(--text)}
.dropdown-item i{width:16px;text-align:center;font-size:13px;opacity:0.7}
.dropdown-item:hover i{opacity:1}
.dropdown-item-highlight{background:var(--primary-light);color:var(--primary)}
.dropdown-item-highlight:hover{background:var(--primary);color:#fff}
.dropdown-item-highlight i{color:var(--primary)}
.dropdown-item-highlight:hover i{color:#fff}
.dropdown-item-danger{color:var(--danger)}
.dropdown-item-danger i{color:var(--danger)}
.dropdown-item-danger:hover{background:var(--danger-light);color:var(--danger)}

.content{padding:20px!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;box-shadow:var(--shadow-sm);transition:var(--transition);overflow:hidden;width:100%!important;max-width:100%!important;box-sizing:border-box!important}
.card:hover{box-shadow:var(--shadow)}
.card-header{padding:12px 14px;border-bottom:1px solid var(--border-light);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg-secondary);flex-wrap:wrap}
.card-header i{width:28px;height:28px;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:12px}
.card-body{padding:14px}
.card-footer{padding:10px 14px;border-top:1px solid var(--border-light);background:var(--bg-secondary)}

.section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.8px;margin:16px 0 10px 0;padding-bottom:8px;border-bottom:2px solid var(--border-light)}
.section-title:first-child{margin-top:0}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;width:100%!important;max-width:100%!important;box-sizing:border-box!important}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card);transition:var(--transition);position:relative;overflow:hidden;display:flex;flex-direction:column}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}
.stat-card:nth-child(2)::before{background:var(--gradient-secondary)}
.stat-card:nth-child(3)::before{background:var(--gradient-success)}
.stat-card:nth-child(4)::before{background:var(--gradient-purple)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-card .icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.stat-card:nth-child(1) .icon{background:var(--primary-light);color:var(--primary)}
.stat-card:nth-child(2) .icon{background:var(--info-light);color:var(--info)}
.stat-card:nth-child(3) .icon{background:var(--success-light);color:var(--success)}
.stat-card:nth-child(4) .icon{background:var(--warning-light);color:var(--warning)}
.stat-card .label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;font-weight:600;margin-bottom:4px;display:flex;align-items:center;gap:4px}
.stat-card .value{font-size:24px;font-weight:800;color:var(--text);letter-spacing:-0.5px;line-height:1.1}
.stat-card .currency{font-size:13px;font-weight:600;color:var(--muted);margin-right:2px}
.stat-card .trend{display:inline-flex;align-items:center;gap:3px;margin-top:6px;font-size:11px;font-weight:600;padding:2px 6px;border-radius:var(--radius-xs)}
.stat-card .trend.up{color:var(--success);background:var(--success-light)}
.stat-card .trend.down{color:var(--danger);background:var(--danger-light)}
.stat-icon{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:10px}
.stat-card-sales .stat-icon{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff}
.stat-card-purchases .stat-icon{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff}
.stat-card-items .stat-icon{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);color:#fff}
.stat-card-customers .stat-icon{background:linear-gradient(135deg,#ec4899 0%,#db2777 100%);color:#fff}
.stat-content{flex:1}
.stat-content .label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px}
.stat-content .value{font-size:24px;font-weight:700;margin:2px 0}
.stat-sub{font-size:11px;color:var(--muted);transition:opacity 0.2s ease}
.stat-sub .text-warning{color:var(--warning)}
.stat-sub .text-success{color:var(--success)}
.stat-sub .text-muted{color:var(--muted)}

.quick-links{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;width:100%!important;max-width:100%!important;box-sizing:border-box!important}
.quick-link{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 8px;text-decoration:none;color:var(--text);display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;transition:var(--transition);box-shadow:var(--shadow-sm);cursor:pointer}
.quick-link:hover{border-color:var(--ql-color,var(--primary));background:color-mix(in srgb,var(--ql-color,var(--primary)) 6%,transparent);transform:translateY(-2px);box-shadow:0 3px 10px color-mix(in srgb,var(--ql-color,var(--primary)) 15%,transparent)}
.quick-link i{width:34px;height:34px;background:color-mix(in srgb,var(--ql-color,var(--primary)) 10%,transparent);color:var(--ql-color,var(--primary));border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--transition);flex-shrink:0}
.quick-link:hover i{background:var(--ql-color,var(--primary));color:#fff;transform:scale(1.08)}
.quick-link span{font-weight:600;font-size:11px;line-height:1.3;color:var(--text)}
.quick-btns{display:flex;flex-wrap:wrap;gap:6px}
.quick-btn{padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:11px;font-weight:500;display:flex;align-items:center;gap:5px;transition:var(--transition)}
.quick-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}
.quick-btn i{font-size:11px}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.form-row:last-child{margin-bottom:0}
.field{display:flex;flex-direction:column;gap:3px}
.field label{font-size:11px;font-weight:600;color:var(--text-secondary)}
.field label .req{color:var(--danger);margin-left:2px}
.hint{font-size:9px;color:var(--muted);margin-top:2px}
.field-row{display:flex;gap:6px}
.field-row select,.field-row .input{flex:1}
select,.input,input[type="text"],input[type="number"],input[type="email"],input[type="password"],textarea{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;width:100%;background:var(--card);color:var(--text);transition:var(--transition);font-family:inherit;line-height:1.4}
select:hover,.input:hover,input:hover{border-color:var(--muted)}
select:focus,.input:focus,input:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
.input[readonly],input[readonly]{background:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23A1A5B7' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.check-list{display:flex;flex-direction:column;gap:5px;margin-top:8px}
.check-item{display:flex;align-items:flex-start;gap:8px;cursor:pointer;padding:8px 10px;background:var(--bg-secondary);border:1px solid transparent;border-radius:var(--radius-sm);transition:var(--transition)}
.check-item:hover{background:var(--primary-light);border-color:var(--primary)}
.check-item input[type="checkbox"]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin-top:1px}
.check-item span{font-size:12px;color:var(--text);line-height:1.3;font-weight:500}
.check-item small{font-size:10px;color:var(--muted);display:block;margin-top:1px;font-weight:400}
.check-item>div{flex:1}

.btn{padding:8px 14px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:var(--transition);font-family:inherit;text-decoration:none;line-height:1.4}
.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px var(--primary-glow)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--primary-glow)}
.btn-secondary{background:var(--card);color:var(--text-secondary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--muted)}
.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 2px 8px rgba(0,196,140,0.3)}
.btn-danger{background:var(--gradient-danger);color:#fff;box-shadow:0 2px 8px rgba(246,78,96,0.3)}
.btn-icon{width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.btn-icon:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}
.actions{padding:12px 0;display:flex;gap:8px;justify-content:flex-end}
.btn-sm{padding:5px 10px;font-size:11px}
.btn-lg{padding:10px 18px;font-size:13px}

.info-box{background:var(--info-light);border:1px solid rgba(54,153,255,0.3);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:10px;display:flex;align-items:flex-start;gap:10px}
.info-box i{color:var(--info);font-size:14px;margin-top:1px}
.info-box p{font-size:11px;color:#1E40AF;margin:0;line-height:1.4}
[data-theme="dark"] .info-box p{color:var(--info)}

.table-wrapper{overflow-x:auto!important;border-radius:var(--radius-sm);border:1px solid var(--border);width:100%!important;max-width:100%!important;box-sizing:border-box!important}
table{width:100%;border-collapse:collapse}
table th,table td{padding:10px 12px;text-align:left}
table th{background:var(--bg-secondary);font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid var(--border);white-space:nowrap}
table td{border-bottom:1px solid var(--border-light);font-size:12px;vertical-align:middle}
table tr:last-child td{border-bottom:none}
table tr:hover td{background:var(--bg-secondary)}
.table-responsive{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
.data-table th{background:var(--bg-secondary);font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px}
.data-table tr:hover td{background:var(--bg-secondary)}
.data-table tr:last-child td{border-bottom:none}

.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:600;gap:4px}
.badge-success{background:var(--success-light);color:var(--success)}
.badge-danger{background:var(--danger-light);color:var(--danger)}
.badge-warning{background:var(--warning-light);color:var(--warning)}
.badge-info{background:var(--info-light);color:var(--info)}
.badge-primary{background:var(--primary-light);color:var(--primary)}

#toast{position:fixed;bottom:20px;right:20px;padding:12px 16px;background:var(--text);color:#fff;border-radius:var(--radius-sm);font-size:12px;font-weight:500;display:none;align-items:center;gap:10px;z-index:2000;box-shadow:var(--shadow-xl);animation:toastSlideUp 0.3s ease;max-width:320px}
#toast.show{display:flex}
#toast.success{background:var(--gradient-success)}
#toast.error{background:var(--gradient-danger)}
#toast.warning{background:var(--gradient-warning)}

#loading{position:fixed;inset:0;background:rgba(255,255,255,0.9);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:var(--transition)}
#loading.show{opacity:1;visibility:visible}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}
[data-theme="dark"] #loading{background:rgba(11,13,23,0.9)}

.modal{position:fixed;inset:0;background:rgba(0,0,0,0.5);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:var(--transition);padding:10px;backdrop-filter:blur(4px)}
.modal.show{opacity:1;visibility:visible}

/* Frappe Bootstrap Modals - Don't hide them */
.modal.fade{opacity:1;visibility:visible;display:none;background:transparent}
.modal.fade.show,.modal.fade.in,.modal.in{display:flex!important;opacity:1!important;visibility:visible!important;background:rgba(0,0,0,0.5)!important;z-index:10050!important}
.modal-backdrop{z-index:10040!important;background-color:rgba(0,0,0,0.5)!important}
.modal-backdrop.show,.modal-backdrop.in{opacity:1!important}

.modal-content{background:var(--card);border-radius:var(--radius-lg);width:100%;max-width:400px;max-height:85vh;overflow:hidden;transform:translateY(-20px);transition:var(--transition);box-shadow:var(--shadow-xl);animation:modalSlideIn 0.3s ease}
.modal.show .modal-content{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius) var(--radius) 0 0}
.modal-header h3{margin:0;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--text)}
.modal-header h3 i{color:var(--primary);font-size:14px}
.modal-close{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-xs);font-size:14px;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.modal-close:hover{background:var(--danger);color:#fff}
.modal-body{padding:12px 14px;overflow-y:auto;flex:1;line-height:1.4}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:10px 14px;border-top:1px solid var(--border);background:var(--bg-secondary);border-radius:0 0 var(--radius) var(--radius)}
.modal-sm .modal-content{max-width:340px}
.modal-lg .modal-content,.modal-lg{max-width:500px}
.modal-xl .modal-content,.modal-xl{max-width:650px}
.modal-full .modal-content{max-width:90vw;max-height:90vh}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:all 0.25s ease;padding:10px}
.modal-overlay.show{opacity:1;visibility:visible}
.modal-dialog{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-xl);width:90%;max-width:400px;max-height:85vh;overflow:hidden;transform:scale(0.92) translateY(-15px);transition:transform 0.25s cubic-bezier(0.34,1.56,0.64,1);border:1px solid var(--border)}
.modal-overlay.show .modal-dialog{transform:scale(1) translateY(0)}
[data-theme="dark"] .modal-dialog{border:1px solid var(--border)}

.form-group{margin-bottom:10px}
.form-group:last-child{margin-bottom:0}
.form-group label{display:block;margin-bottom:3px;font-size:11px;font-weight:600;color:var(--text-secondary)}
.form-group label .req{color:var(--danger)}
.form-control{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;background:var(--card);color:var(--text);transition:var(--transition);font-family:inherit;line-height:1.4}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
.form-control.error{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-light)}
.form-control::placeholder{color:var(--muted)}
.form-control-sm{padding:5px 8px;font-size:11px}
select.form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23A1A5B7' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
[data-theme="dark"] .form-control{background:var(--bg-secondary)}

.profile-header{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius);margin-bottom:12px}
.profile-avatar{width:50px;height:50px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}
.profile-info h2{margin:0 0 2px 0;font-size:15px;font-weight:700;color:var(--text)}
.profile-info p{margin:0 0 4px 0;color:var(--muted);font-size:11px}
.profile-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.section-divider{display:flex;align-items:center;margin:14px 0 10px;color:var(--muted);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.section-divider::before,.section-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.section-divider span{padding:0 10px}

.settings-group{margin-bottom:6px}
.settings-item{display:flex;align-items:center;justify-content:space-between;padding:10px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}
.settings-item:hover{background:var(--border-light)}
.settings-item-info{display:flex;align-items:center;gap:10px}
.settings-item-info>i{width:30px;height:30px;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:13px}
.settings-item-info h4{margin:0 0 1px 0;font-size:12px;font-weight:600;color:var(--text)}
.settings-item-info p{margin:0;font-size:10px;color:var(--muted)}
.switch{position:relative;display:inline-block;width:40px;height:22px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:22px;transition:var(--transition)}
.slider::before{content:'';position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:var(--transition);box-shadow:0 2px 4px rgba(0,0,0,0.2)}
input:checked+.slider{background:var(--primary)}
input:checked+.slider::before{transform:translateX(18px)}

.form-section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin:12px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--border-light)}
.form-section-title:first-child{margin-top:0}

.modal-search{max-width:500px;border-radius:var(--radius-lg);overflow:hidden}
.search-modal-header{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}
.search-modal-header i{font-size:16px;color:var(--muted)}
.search-modal-header input{flex:1;border:none;background:transparent;font-size:13px;color:var(--text);outline:none}
.search-modal-header input::placeholder{color:var(--muted)}
.search-modal-body{padding:12px 14px;max-height:280px;overflow-y:auto}
.search-shortcut-title{display:block;font-size:9px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:10px}
.search-shortcut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.search-shortcut-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius);text-decoration:none;color:var(--text);transition:var(--transition)}
.search-shortcut-item:hover{background:var(--primary-light);color:var(--primary);transform:translateY(-2px)}
.search-shortcut-item i{font-size:16px;color:var(--primary)}
.search-shortcut-item span{font-size:10px;font-weight:500;text-align:center}

.mobile-menu-btn{display:none;position:fixed;top:10px;left:10px;z-index:200;width:38px;height:38px;border:none;background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);color:var(--text);font-size:16px;cursor:pointer;align-items:center;justify-content:center;transition:var(--transition)}
.mobile-menu-btn:hover{background:var(--primary);color:#fff}

.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}
.user-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}
.user-avatar-large{width:44px;height:44px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}
.user-info-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.user-info-header h4{margin:0 0 2px 0;font-size:14px;font-weight:600}
.roles-tags{display:flex;flex-wrap:wrap;gap:4px}
.role-tag{display:inline-block;padding:2px 6px;background:var(--primary-light);color:var(--primary);border-radius:10px;font-size:9px;font-weight:500}
.role-tag-more{background:var(--bg-secondary);color:var(--text-secondary)}
.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
.role-card{display:flex;align-items:center;gap:8px;padding:10px;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:all 0.2s}
.role-card:hover{background:var(--primary-light);transform:translateY(-2px)}
.role-icon{width:32px;height:32px;background:var(--card);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:12px}
.role-card:hover .role-icon{background:var(--gradient-primary);color:#fff}
.role-info{flex:1}
.role-name{font-weight:600;font-size:11px}
.role-count{font-size:10px;color:var(--text-secondary)}
.roles-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:4px;max-height:220px;overflow-y:auto;padding:2px}
.role-checkbox{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--bg-secondary);border-radius:4px;cursor:pointer;transition:all 0.15s;font-size:11px}
.role-checkbox:hover{background:var(--primary-light)}
.role-checkbox input[type="checkbox"]{width:14px;height:14px;accent-color:var(--primary);cursor:pointer}
.role-checkbox.role-admin{border:1px solid var(--warning);background:rgba(255,168,0,0.1)}
.role-checkbox.role-admin:hover{background:rgba(255,168,0,0.2)}
.role-users-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto}
.role-user-item{display:flex;align-items:center;gap:8px;padding:8px;background:var(--bg-secondary);border-radius:6px}
.role-user-info{flex:1}

.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:20px;width:100%!important;max-width:100%!important;box-sizing:border-box!important}
.dashboard-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-card)}
.dashboard-card-wide{grid-column:span 2}
.dashboard-card-header{padding:10px 14px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary)}
.dashboard-card-header h4{margin:0;font-size:12px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}
.dashboard-card-header h4 i{color:var(--primary)}
.dashboard-card-body{padding:12px 14px;min-height:170px}
.view-all{font-size:11px;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:3px;font-weight:500}
.view-all:hover{text-decoration:underline}

.ranking-list{display:flex;flex-direction:column;gap:6px}
.ranking-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-secondary);transition:var(--transition)}
.ranking-item:hover{background:var(--primary-light)}
.rank{width:24px;height:24px;border-radius:50%;background:var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.ranking-item:nth-child(1) .rank{background:linear-gradient(135deg,#FFD700,#FFA500);color:#fff}
.ranking-item:nth-child(2) .rank{background:linear-gradient(135deg,#C0C0C0,#A0A0A0);color:#fff}
.ranking-item:nth-child(3) .rank{background:linear-gradient(135deg,#CD7F32,#8B4513);color:#fff}
.ranking-info{flex:1;min-width:0}
.ranking-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ranking-detail{font-size:10px;color:var(--muted)}
.ranking-value{font-size:12px;font-weight:600;text-align:right}

.top-items-list,.top-customers-list{display:flex;flex-direction:column;gap:8px}
.top-item,.top-customer{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}
.top-item:hover,.top-customer:hover{background:var(--primary-light)}
.top-item-rank,.top-customer-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;font-size:11px;font-weight:700;border-radius:50%;flex-shrink:0}
.top-item-info,.top-customer-info{flex:1;min-width:0}
.top-item-name,.top-customer-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-item-qty,.top-customer-invoices{font-size:11px;color:var(--muted);margin-top:2px}
.top-item-amount,.top-customer-amount{font-size:13px;font-weight:700;color:var(--success);text-align:left;white-space:nowrap}

.recent-list{display:flex;flex-direction:column;gap:8px}
.recent-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}
.recent-item:hover{background:var(--primary-light)}
.recent-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);flex-shrink:0}
.recent-info{flex:1;min-width:0}
.recent-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent-sub{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent-meta{text-align:left;flex-shrink:0}
.recent-amount{font-size:13px;font-weight:700;color:var(--text)}
.recent-status{font-size:10px;font-weight:600;margin-top:2px}
.recent-status.status-paid{color:var(--success)}
.recent-status.status-unpaid{color:var(--warning)}
.recent-status.status-overdue{color:var(--danger)}

.low-stock-list{display:flex;flex-direction:column;gap:8px}
.low-stock-item{display:flex!important;flex-direction:row!important;align-items:center!important;gap:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}
.low-stock-item:hover{background:var(--warning-light,rgba(245,158,11,0.1))}
.low-stock-item .low-stock-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--warning-light,rgba(245,158,11,0.1));color:var(--warning);border-radius:var(--radius-sm);flex-shrink:0}
.low-stock-item .low-stock-info{flex:1;min-width:0}
.low-stock-item .low-stock-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.low-stock-item .low-stock-warehouse{font-size:11px;color:var(--muted);margin-top:2px}
.low-stock-item .low-stock-qty{font-size:14px;font-weight:700;color:var(--warning);flex-shrink:0}

.chart-container{display:flex;flex-direction:row-reverse;gap:20px;height:180px;align-items:stretch}
.chart-period-btns{display:flex;gap:4px;background:var(--bg-secondary);padding:3px;border-radius:var(--radius-sm)}
.chart-period-btn{padding:6px 14px;font-size:12px;font-weight:500;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--muted);transition:var(--transition)}
.chart-period-btn:hover{color:var(--text);border-color:var(--primary)}
.chart-period-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.chart-summary{width:140px;display:flex;flex-direction:column;justify-content:center;gap:8px;flex-shrink:0}
.chart-label{font-size:11px;color:var(--muted);margin-bottom:4px}
.chart-total{font-size:22px;font-weight:700;color:var(--primary)}
.chart-bars{flex:1;display:flex;align-items:flex-end;gap:6px;padding-bottom:30px;position:relative;min-height:120px;border-bottom:1px solid var(--border)}
.chart-bar{flex:1;min-width:16px;min-height:4px;background:linear-gradient(180deg,var(--primary) 0%,#4338ca 100%);border-radius:4px 4px 0 0;position:relative;cursor:pointer;transition:all 0.2s ease}
.chart-bar:hover{opacity:0.85;transform:scaleY(1.03)}
.chart-bar::after{content:attr(data-label);position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);font-size:9px;color:var(--muted);white-space:nowrap}

.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--muted)}
.empty-state i{font-size:36px;margin-bottom:10px;opacity:0.4}
.empty-state p{margin:0;font-size:12px}
.empty-state.success{color:var(--success)}
.empty-state.success i{opacity:1}
.loading-placeholder{display:flex;align-items:center;justify-content:center;padding:50px 16px;color:var(--primary);font-size:20px}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
.sidebar-menu::-webkit-scrollbar{width:4px}
.sidebar-menu::-webkit-scrollbar-track{background:transparent}
.sidebar-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:2px}

.stock-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px;padding:16px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border)}
.stock-actions .btn{flex:1;min-width:140px;justify-content:center}
.header-actions{display:flex;align-items:center;gap:10px}
.item-thumb{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border)}
.item-thumb-placeholder{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:16px}
.stock-zero{color:var(--danger)!important;font-weight:600}
.stock-low{color:var(--warning)!important;font-weight:600}
.row-disabled{opacity:0.6;background:var(--bg-secondary)}
.row-disabled td{text-decoration:line-through}
.action-btns{display:flex;gap:6px}
.btn-danger-icon{color:var(--danger)!important;border-color:var(--danger-light)!important}
.btn-danger-icon:hover{background:var(--danger)!important;color:#fff!important}
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:16px;border-top:1px solid var(--border)}
.page-btn{min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.page-btn:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.page-btn:disabled{opacity:0.5;cursor:not-allowed}
.page-dots{padding:0 8px;color:var(--muted)}
.badge-light{background:var(--bg-secondary);color:var(--text-secondary);font-size:11px;padding:4px 8px;border-radius:var(--radius-xs)}
.item-detail-header{display:grid;grid-template-columns:auto 1fr auto;gap:20px;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:20px}
.item-detail-image{width:100px;height:100px;border-radius:var(--radius);object-fit:cover;border:2px solid var(--border)}
.item-detail-image-placeholder{width:100px;height:100px;border-radius:var(--radius);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--muted)}
.item-detail-info h3{margin:0 0 8px 0;font-size:20px;font-weight:600}
.item-detail-info .item-code{color:var(--primary);font-weight:500;margin:0 0 8px 0}
.item-detail-info .item-group,.item-detail-info .item-brand{color:var(--text-secondary);font-size:13px;margin:4px 0}
.item-detail-info i{width:16px;margin-left:4px}
.item-detail-stock{display:flex;flex-direction:column;gap:8px}
.stock-box{background:var(--bg-secondary);padding:10px 14px;border-radius:var(--radius-sm);text-align:center;min-width:100px}
.stock-box .stock-label{display:block;font-size:11px;color:var(--muted);margin-bottom:4px}
.stock-box .stock-value{display:block;font-size:20px;font-weight:700}
.stock-box.available{background:var(--success-light)}
.stock-box.available .stock-value{color:var(--success)}
.mini-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:16px}
.mini-table th,.mini-table td{padding:10px 12px;border-bottom:1px solid var(--border-light)}
.mini-table th{background:var(--bg-secondary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.5px}
.mini-table tr:last-child td{border-bottom:none}
.mini-table a{color:var(--primary);text-decoration:none}
.mini-table a:hover{text-decoration:underline}
.se-items-header{display:flex;gap:10px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:10px}
.se-items-list{display:flex;flex-direction:column;gap:8px;max-height:250px;overflow-y:auto}
.se-item-row{display:flex;gap:10px;align-items:center;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);transition:var(--transition)}
.se-item-row:hover{background:var(--primary-light)}
.se-item-field{display:flex;flex-direction:column}
.se-item-field .input{padding:8px 10px;font-size:13px}
.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-height:250px;overflow-y:auto;z-index:1000;margin-top:2px}
.search-item{padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--border-light);transition:background 0.15s}
.search-item:last-child{border-bottom:none}
.search-item:hover,.search-item.highlighted{background:var(--primary-light)}
.search-item-title{font-size:13px;font-weight:500;color:var(--text)}
.search-item-sub{font-size:11px;color:var(--muted);display:flex;justify-content:space-between;margin-top:2px}
.search-item-price{font-weight:600;color:var(--success)}
.search-item.no-result{color:var(--muted);text-align:center;cursor:default}
.search-item.no-result:hover{background:transparent}
.input-sm{padding:6px 10px!important;font-size:12px!important;height:32px!important}
.input-xs{padding:4px 8px!important;font-size:11px!important;height:26px!important;text-align:right}
.field.compact{margin-bottom:0}
.field.compact label{font-size:11px;margin-bottom:3px;color:var(--text-secondary)}
.btn-icon-sm{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.btn-icon-sm:hover{background:var(--primary);color:white;border-color:var(--primary)}
.btn-icon-xs{width:24px;height:24px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-xs);cursor:pointer;font-size:11px;transition:var(--transition)}
.btn-icon-xs.btn-danger:hover{background:var(--danger);color:white}
.compact-table{font-size:12px}
.compact-table th,.compact-table td{padding:6px 8px!important}
.compact-table th{background:var(--bg-secondary);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:0.5px}
.check-item.compact{font-size:12px}
.check-item.compact input[type="checkbox"]{width:14px;height:14px}
.invoice-totals-box{background:linear-gradient(135deg,var(--bg-secondary) 0%,#f8f9fa 100%);border:1px solid var(--border);border-radius:var(--radius);padding:12px}
.total-line{display:flex;justify-content:space-between;align-items:center;padding:6px 0}
.total-line:not(:last-child){border-bottom:1px solid var(--border-light)}
.status-badge{display:inline-block;padding:3px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:600}
.status-success{background:rgba(34,197,94,0.1);color:#16a34a}
.status-danger{background:rgba(239,68,68,0.1);color:#dc2626}
.status-warning{background:rgba(245,158,11,0.1);color:#d97706}
.status-info{background:rgba(59,130,246,0.1);color:#2563eb}
.status-muted{background:rgba(107,114,128,0.1);color:#6b7280}
.req{color:var(--danger);font-weight:bold}
.inv-form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.inv-form-grid .field{min-width:0}
#new-inv-barcode:focus,#new-inv-customer-search:focus,#new-inv-item-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.1)}
#new-inv-items{min-height:50px}
#new-inv-items tr:hover{background:var(--bg-secondary)}
#new-inv-items tr{animation:slideIn 0.2s ease-out}
#new-inv-payment-section{background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);padding:10px;border-radius:var(--radius-sm);border:1px solid #bbf7d0}
.modal-footer .btn{min-width:100px}

.tax-tabs{display:flex;gap:8px;padding:16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}
.tax-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);display:flex;align-items:center;gap:8px;font-family:inherit}
.tax-tab i{font-size:14px}
.tax-tab:hover{background:var(--border-light);color:var(--text)}
.tax-tab.active{background:var(--primary);color:#fff}
.tax-tab-content{padding:20px;min-height:400px}
.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.tab-header h4{margin:0;font-size:18px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:10px}
.tab-header h4 i{color:var(--primary)}
.templates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.template-card{background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.template-card:hover{border-color:var(--primary);box-shadow:0 4px 16px rgba(99,102,241,0.12)}
.template-card.disabled{opacity:0.7}
.template-card.disabled .template-header{background:var(--bg-secondary)}
.template-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-bottom:1px solid var(--border-light)}
.template-info h5{margin:0 0 4px 0;font-size:16px;font-weight:600;color:var(--text)}
.template-company{font-size:12px;color:var(--text-muted)}
.template-badges{display:flex;gap:6px;flex-wrap:wrap}
.template-body{padding:16px}
.tax-summary{display:flex;gap:24px;margin-bottom:16px}
.tax-rate-display,.tax-count{text-align:center}
.rate-value,.count-value{display:block;font-size:28px;font-weight:700;color:var(--primary);line-height:1}
.rate-label,.count-label{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-top:4px}
.tax-details{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:12px}
.tax-line{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}
.tax-line:not(:last-child){border-bottom:1px solid var(--border-light)}
.tax-desc{color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:12px}
.tax-rate{font-weight:600;color:var(--text)}
.tax-line.more{color:var(--text-muted);font-style:italic;justify-content:center}
.template-actions{display:flex;gap:8px;padding:12px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-light)}
.template-actions .btn{flex:1}
.tax-line-row{padding:12px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:10px}
.tax-line-fields{display:flex;gap:12px;align-items:flex-start}
.tax-line-fields .hs-form-group{margin-bottom:0}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}
.btn-outline:hover{background:var(--bg-secondary);border-color:var(--primary);color:var(--primary)}
.btn-outline.btn-danger:hover{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}
.btn-icon-only{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hs-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text)}
.hs-checkbox-label input[type="checkbox"]{width:18px;height:18px;cursor:pointer}

.hs-rpt-container{padding:0}
.hs-rpt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}
.hs-rpt-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}
.hs-rpt-title i{color:var(--primary)}
.hs-rpt-actions{display:flex;gap:6px}
.hs-rpt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.hs-rpt-grid.hs-rpt-hidden{display:none}
.hs-rpt-card{background:var(--card-bg);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;transition:var(--transition);border:1px solid var(--border-color);display:flex;align-items:center;gap:10px}
.hs-rpt-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.1);border-color:var(--primary)}
.hs-rpt-card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;color:white;flex-shrink:0}
.hs-rpt-card-info h4{font-size:12px;font-weight:600;color:var(--text-primary);margin:0 0 1px 0;line-height:1.2}
.hs-rpt-card-info p{font-size:10px;color:var(--text-muted);margin:0;line-height:1.2}
.hs-rpt-section{background:var(--card-bg);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border-color)}
.hs-rpt-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color);gap:8px}
.hs-rpt-section-header h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:6px}
.hs-rpt-section-header h3 i{color:var(--primary);font-size:12px}
.hs-rpt-section-actions{display:flex;gap:6px}
.hs-rpt-section-actions .btn{padding:5px 10px;font-size:11px}
.hs-rpt-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px;padding:8px 10px;background:var(--bg-light);border-radius:var(--radius-sm);align-items:flex-end}
.hs-rpt-filter{display:flex;flex-direction:column;gap:3px}
.hs-rpt-filter label{font-size:10px;font-weight:500;color:var(--text-muted)}
.hs-rpt-filter input,.hs-rpt-filter select{padding:5px 8px;border:1px solid var(--border-color);border-radius:5px;font-size:12px;background:var(--card-bg);color:var(--text-primary);min-width:120px;height:30px}
.hs-rpt-filter .btn{height:30px;padding:0 14px;font-size:12px}
.hs-rpt-summary{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.hs-rpt-summary-card{background:var(--bg-light);border-radius:var(--radius-sm);padding:8px 12px;display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);flex:1;min-width:140px}
.hs-rpt-summary-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px;color:white;flex-shrink:0}
.hs-rpt-summary-info{display:flex;flex-direction:column}
.hs-rpt-summary-value{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1.2}
.hs-rpt-summary-label{font-size:10px;color:var(--text-muted)}
.hs-rpt-chart{height:180px;margin-bottom:10px;padding:8px;background:var(--bg-light);border-radius:var(--radius-sm)}
.hs-rpt-table-wrap{overflow-x:auto;margin-bottom:6px}
.hs-rpt-table{width:100%;border-collapse:collapse;font-size:11px}
.hs-rpt-table th,.hs-rpt-table td{padding:6px 8px;text-align:right;border-bottom:1px solid var(--border-color)}
.hs-rpt-table th{background:var(--bg-light);font-weight:600;color:var(--text-muted);font-size:10px;text-transform:uppercase;letter-spacing:0.3px;white-space:nowrap}
.hs-rpt-table td{color:var(--text-primary)}
.hs-rpt-table tbody tr:hover{background:var(--bg-light)}
.hs-rpt-table .hs-rpt-center{text-align:center}
.hs-rpt-table .hs-rpt-right{text-align:right}
.hs-rpt-table .hs-rpt-left{text-align:left}
.hs-rpt-table .hs-rpt-success{color:#10B981}
.hs-rpt-table .hs-rpt-danger{color:#EF4444}
.hs-rpt-table .hs-rpt-warning{color:#F59E0B}
.hs-rpt-table .hs-rpt-muted{color:var(--text-muted);font-size:9px}
.hs-rpt-table tfoot tr{background:var(--bg-light)!important;font-weight:600}
.hs-rpt-table tfoot td{border-top:2px solid var(--border-color)}
.hs-rpt-badge{display:inline-block;padding:2px 6px;font-size:9px;font-weight:500;border-radius:10px}
.hs-rpt-badge-primary{background:rgba(99,102,241,0.1);color:#6366F1}
.hs-rpt-badge-success{background:rgba(16,185,129,0.1);color:#10B981}
.hs-rpt-badge-warning{background:rgba(245,158,11,0.1);color:#F59E0B}
.hs-rpt-badge-danger{background:rgba(239,68,68,0.1);color:#EF4444}
.hs-rpt-progress{display:flex;align-items:center;gap:6px;min-width:100px}
.hs-rpt-progress-bar{flex:1;height:5px;background:var(--primary);border-radius:3px;max-width:70px}
.hs-rpt-progress span{font-size:10px;font-weight:500;min-width:40px}
.hs-rpt-loading{display:flex;flex-direction:column;align-items:center;padding:30px;color:var(--text-muted)}
.hs-rpt-spinner{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:hs-rpt-spin 1s linear infinite;margin-bottom:8px}
.hs-rpt-pagination{display:flex;justify-content:space-between;align-items:center;padding:8px 0;gap:8px;border-top:1px solid var(--border-color);margin-top:6px}
.hs-rpt-pagination-info{font-size:11px;color:var(--text-muted)}
.hs-rpt-pagination-info strong{color:var(--text-primary)}
.hs-rpt-pagination-btns{display:flex;gap:2px}
.hs-rpt-pagination-btn{min-width:26px;height:26px;padding:0 6px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);font-size:11px;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.hs-rpt-pagination-btn:hover:not(:disabled){background:var(--primary);color:white;border-color:var(--primary)}
.hs-rpt-pagination-btn.active{background:var(--primary);color:white;border-color:var(--primary)}
.hs-rpt-pagination-btn:disabled{opacity:0.4;cursor:not-allowed}
.hs-rpt-pagination-size{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted)}
.hs-rpt-pagination-size select{padding:3px 6px;border:1px solid var(--border-color);border-radius:var(--radius-xs);font-size:11px}
[dir="rtl"] .hs-rpt-table th,[dir="rtl"] .hs-rpt-table td{text-align:right}
[dir="rtl"] .hs-rpt-table .hs-rpt-left{text-align:right}
[dir="rtl"] .hs-rpt-table .hs-rpt-right{text-align:left}

.hs-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:hsModalFadeIn 0.2s ease}
.hs-modal-overlay.hs-modal-closing{animation:hsModalFadeOut 0.2s ease forwards}
.hs-modal{background:var(--card);border-radius:var(--radius);box-shadow:0 20px 40px -12px rgba(0,0,0,0.25);width:90%;max-width:450px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:hsModalSlideIn 0.25s ease}
.hs-modal.hs-modal-lg{max-width:550px}
.hs-modal.hs-modal-xl{max-width:700px}
.hs-modal-closing .hs-modal{animation:hsModalSlideOut 0.2s ease forwards}
.hs-modal-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary)}
.hs-modal-header h3{margin:0;font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.hs-modal-header h3 i{color:var(--primary);font-size:16px}
.hs-modal-close{width:28px;height:28px;border:none;background:transparent;color:var(--muted);font-size:18px;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.hs-modal-close:hover{background:var(--danger-light);color:var(--danger)}
.hs-modal-body{padding:12px 16px;overflow-y:auto;flex:1}
.hs-modal-footer{padding:10px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-secondary)}
.hs-profile-header{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:12px}
.hs-profile-avatar{width:50px;height:50px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}
.hs-profile-info h2{margin:0 0 2px 0;font-size:15px;font-weight:600;color:var(--text)}
.hs-profile-info p{margin:0;color:var(--muted);font-size:12px;line-height:1.3}
.hs-form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.hs-form-group{margin-bottom:8px}
.hs-form-group:last-child{margin-bottom:0}
.hs-form-group label{display:block;margin-bottom:3px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.3px}
.hs-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--card);color:var(--text);transition:var(--transition);font-family:inherit}
.hs-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(99,102,241,0.12)}
.hs-input:disabled{background:var(--bg-secondary);color:var(--muted);cursor:not-allowed}
.hs-input::placeholder{color:var(--muted)}
textarea.hs-input{resize:vertical;min-height:50px}
.hs-select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--card);color:var(--text);cursor:pointer;min-width:100px}
.hs-select:focus{outline:none;border-color:var(--primary)}
.hs-section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin:12px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border-light)}
.hs-section-title:first-child{margin-top:0}
.hs-setting-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:6px;transition:var(--transition)}
.hs-setting-item:hover{background:var(--border-light)}
.hs-setting-item:last-child{margin-bottom:0}
.hs-setting-info{display:flex;align-items:center;gap:10px;flex:1}
.hs-setting-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:14px}
.hs-setting-text h4{margin:0;font-size:13px;font-weight:500;color:var(--text)}
.hs-setting-text p{margin:1px 0 0 0;font-size:11px;color:var(--muted)}
.hs-toggle{position:relative;width:40px;height:22px;cursor:pointer}
.hs-toggle input{opacity:0;width:0;height:0}
.hs-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border);transition:0.3s;border-radius:22px}
.hs-toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:white;transition:0.3s;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.hs-toggle input:checked+.hs-toggle-slider{background:var(--primary)}
.hs-toggle input:checked+.hs-toggle-slider:before{transform:translateX(18px)}
.hs-btn{padding:7px 14px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;font-family:inherit}
.hs-btn-primary{background:var(--primary);color:#fff}
.hs-btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}
.hs-btn-secondary{background:var(--bg-secondary);color:var(--text)}
.hs-btn-secondary:hover{background:var(--border)}
.hs-btn-danger{background:var(--danger);color:#fff}
.hs-btn-danger:hover{background:#dc2626}
.hs-btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.hs-btn-outline:hover{background:var(--bg-secondary);border-color:var(--primary);color:var(--primary)}
.hs-btn-sm{padding:5px 10px;font-size:11px}
.hs-btn-lg{padding:10px 18px;font-size:14px}
.hs-info-box{padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:10px}
.hs-info-box:last-child{margin-bottom:0}
.hs-info-box label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.3px;margin-bottom:2px;display:block}
.hs-info-box span{font-size:13px;color:var(--text);font-weight:500}
.hs-company-header{display:flex;align-items:center;gap:12px;padding:10px;background:var(--gradient-primary);border-radius:var(--radius-sm);margin-bottom:12px;color:#fff}
.hs-company-logo{width:50px;height:50px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.hs-company-logo img{width:100%;height:100%;object-fit:contain;border-radius:var(--radius-sm)}
.hs-company-info h2{margin:0 0 2px 0;font-size:15px;font-weight:600}
.hs-company-info p{margin:0;font-size:11px;opacity:0.9}
.hs-badge{padding:2px 6px;border-radius:var(--radius-xs);font-size:10px;font-weight:600}
.hs-badge-success{background:#dcfce7;color:#16a34a}
.hs-badge-warning{background:#fef3c7;color:#d97706}
.hs-badge-danger{background:#fee2e2;color:#dc2626}
.hs-badge-info{background:#dbeafe;color:#2563eb}
.hs-password-change{padding:10px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-top:10px}
.hs-password-change h4{margin:0 0 8px 0;font-size:12px;font-weight:600;color:var(--text)}
.hs-modal-body::-webkit-scrollbar{width:5px}
.hs-modal-body::-webkit-scrollbar-track{background:transparent}
.hs-modal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.hs-modal-body::-webkit-scrollbar-thumb:hover{background:var(--muted)}

@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.6;transform:scale(0.9)}}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
@keyframes submenuSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes dropdownFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes modalSlideIn{from{opacity:0;transform:translateY(-20px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes slideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes hs-rpt-spin{to{transform:rotate(360deg)}}
@keyframes hsModalFadeIn{from{opacity:0}to{opacity:1}}
@keyframes hsModalFadeOut{from{opacity:1}to{opacity:0}}
@keyframes hsModalSlideIn{from{opacity:0;transform:scale(0.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes hsModalSlideOut{from{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(0.95) translateY(-10px)}}

.text-center{text-align:center!important}
.text-left{text-align:left!important}
.text-right{text-align:right!important}
.text-primary{color:var(--primary)!important}
.text-success{color:var(--success)!important}
.text-danger{color:var(--danger)!important}
.text-warning{color:var(--warning)!important}
.text-muted{color:var(--muted)!important}
.d-none{display:none!important}
.d-flex{display:flex!important}
.d-block{display:block!important}
.w-100{width:100%!important}
.h-100{height:100%!important}
.mt-1{margin-top:4px!important}
.mt-2{margin-top:8px!important}
.mt-3{margin-top:12px!important}
.mb-1{margin-bottom:4px!important}
.mb-2{margin-bottom:8px!important}
.mb-3{margin-bottom:12px!important}
.truncate{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}

[data-theme="dark"] .tax-tabs{background:var(--bg-secondary);border-color:var(--border)}
[data-theme="dark"] .tax-tab:hover{background:var(--border)}
[data-theme="dark"] .template-card{background:var(--card);border-color:var(--border)}
[data-theme="dark"] .template-header{background:linear-gradient(135deg,#1f2937 0%,#111827 100%);border-color:var(--border)}
[data-theme="dark"] .tax-details{background:rgba(0,0,0,0.2)}
[data-theme="dark"] .template-actions{background:rgba(0,0,0,0.2);border-color:var(--border)}
[data-theme="dark"] .tax-line-row{background:rgba(0,0,0,0.2)}
[data-theme="dark"] .badge-primary{background:rgba(99,102,241,0.2)}
[data-theme="dark"] .badge-success{background:rgba(22,163,74,0.2)}
[data-theme="dark"] .badge-danger{background:rgba(220,38,38,0.2)}
[data-theme="dark"] .btn-outline{border-color:var(--border);color:var(--text-secondary)}
[data-theme="dark"] .hs-modal,.dark-theme .hs-modal{background:var(--card);border:1px solid var(--border)}
[data-theme="dark"] .hs-modal-header,.dark-theme .hs-modal-header,[data-theme="dark"] .hs-modal-footer,.dark-theme .hs-modal-footer{background:var(--bg-secondary);border-color:var(--border)}
[data-theme="dark"] .hs-input,.dark-theme .hs-input,[data-theme="dark"] .hs-select,.dark-theme .hs-select{background:var(--bg-secondary);border-color:var(--border);color:var(--text)}
[data-theme="dark"] .hs-profile-header,.dark-theme .hs-profile-header,[data-theme="dark"] .hs-setting-item,.dark-theme .hs-setting-item,[data-theme="dark"] .hs-info-box,.dark-theme .hs-info-box,[data-theme="dark"] .hs-password-change,.dark-theme .hs-password-change{background:var(--bg-secondary)}
[data-theme="dark"] #new-inv-payment-section{background:linear-gradient(135deg,rgba(16,185,129,0.1) 0%,rgba(34,197,94,0.1) 100%);border-color:rgba(34,197,94,0.3)}
[data-theme="dark"] .invoice-totals-box{background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(0,0,0,0.2) 100%)}

/* ============================================
   COLLAPSIBLE SIDEBAR
   ============================================ */
:root{--sidebar-collapsed-width:64px}

.sidebar-toggle-btn{
    position:absolute;top:14px;right:10px;
    width:28px;height:28px;border:none;border-radius:8px;
    background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    font-size:12px;transition:all 0.2s;z-index:2;
}
.sidebar-toggle-btn:hover{background:rgba(255,255,255,0.2);color:#fff}
[dir="rtl"] .sidebar-toggle-btn{right:auto;left:10px}

.sidebar-separator{height:1px;background:rgba(255,255,255,0.08);margin:6px 12px}
.sidebar-section-title{padding:4px 14px;font-size:9px;font-weight:700;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.5px;margin:10px 0 4px}

/* Collapsed state */
.sidebar.collapsed{width:var(--sidebar-collapsed-width)!important}
.sidebar.collapsed .menu-text{display:none!important}
.sidebar.collapsed .arrow{display:none!important}
.sidebar.collapsed .submenu{display:none!important}
.sidebar.collapsed .sidebar-separator{margin:6px 8px}
.sidebar.collapsed .sidebar-section-title{display:none}

.sidebar.collapsed .sidebar-header{padding:14px 8px;text-align:center}
.sidebar.collapsed .sidebar-logo{justify-content:center}
.sidebar.collapsed .sidebar-logo i{width:34px;height:34px;font-size:15px}

.sidebar.collapsed .sidebar-menu{padding:8px 6px}
.sidebar.collapsed .menu-item{justify-content:center;padding:10px 0;gap:0}
.sidebar.collapsed .menu-item i{width:auto;font-size:16px;opacity:1}
.sidebar.collapsed .menu-item.active::before{left:-6px}

.sidebar.collapsed .sidebar-footer{padding:8px 6px}
.sidebar.collapsed .sidebar-user-mini{justify-content:center;padding:8px 4px}
.sidebar.collapsed .logout-btn{justify-content:center;padding:8px 4px}
.sidebar.collapsed .logout-btn i{width:auto}

.sidebar.collapsed .sidebar-toggle-btn{position:static;margin:6px auto 0;right:auto}
[dir="rtl"] .sidebar.collapsed .sidebar-toggle-btn{left:auto}

/* Main content adjusts when collapsed */
.app.sidebar-collapsed .main{
    margin-left:var(--sidebar-collapsed-width)!important;
    width:calc(100% - var(--sidebar-collapsed-width))!important;
    max-width:calc(100% - var(--sidebar-collapsed-width))!important;
}

/* RTL collapsed */
[dir="rtl"] .app.sidebar-collapsed .main,
html[lang="ar"] .app.sidebar-collapsed .main,
body.rtl .app.sidebar-collapsed .main{
    margin-left:0!important;
    margin-right:var(--sidebar-collapsed-width)!important;
    width:calc(100% - var(--sidebar-collapsed-width))!important;
    max-width:calc(100% - var(--sidebar-collapsed-width))!important;
}

/* Hover expand - sidebar temporarily expands on hover */
.sidebar.collapsed:hover{
    width:var(--sidebar-width)!important;
    box-shadow:4px 0 30px rgba(49,46,129,0.35);
}
[dir="rtl"] .sidebar.collapsed:hover{
    box-shadow:-4px 0 30px rgba(49,46,129,0.35);
}
.sidebar.collapsed:hover .menu-text{display:inline!important}
.sidebar.collapsed:hover .arrow{display:inline!important}
.sidebar.collapsed:hover .submenu.open{display:block!important}
.sidebar.collapsed:hover .sidebar-separator{margin:6px 12px}
.sidebar.collapsed:hover .sidebar-section-title{display:block}
.sidebar.collapsed:hover .sidebar-header{padding:16px 14px;text-align:left}
[dir="rtl"] .sidebar.collapsed:hover .sidebar-header{text-align:right}
.sidebar.collapsed:hover .sidebar-logo{justify-content:flex-start}
.sidebar.collapsed:hover .sidebar-logo i{width:38px;height:38px;font-size:16px}
.sidebar.collapsed:hover .sidebar-menu{padding:10px 8px}
.sidebar.collapsed:hover .menu-item{justify-content:flex-start;padding:9px 12px;gap:8px}
.sidebar.collapsed:hover .menu-item i{width:18px;font-size:14px}
.sidebar.collapsed:hover .menu-item.active::before{left:0}
.sidebar.collapsed:hover .sidebar-footer{padding:10px 8px}
.sidebar.collapsed:hover .sidebar-user-mini{justify-content:flex-start;padding:8px 10px}
.sidebar.collapsed:hover .logout-btn{justify-content:flex-start;padding:8px 12px}
.sidebar.collapsed:hover .logout-btn i{width:16px}
.sidebar.collapsed:hover .sidebar-toggle-btn{position:absolute;top:14px;right:10px;margin:0}
[dir="rtl"] .sidebar.collapsed:hover .sidebar-toggle-btn{right:auto;left:10px}

/* Tooltip for collapsed menu items */
.sidebar.collapsed .menu-item{position:relative}
.sidebar.collapsed .menu-item[title]:hover::after{
    content:attr(data-tooltip);
    position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);
    background:rgba(0,0,0,0.85);color:#fff;padding:4px 10px;border-radius:6px;
    font-size:12px;white-space:nowrap;z-index:200;pointer-events:none;
}
[dir="rtl"] .sidebar.collapsed .menu-item[title]:hover::after{
    left:auto;right:calc(100% + 8px);
}

@media (min-width:1400px){.stats-grid{grid-template-columns:repeat(4,1fr)}.dashboard-grid{grid-template-columns:repeat(3,1fr)}.dashboard-card-wide{grid-column:span 2}}
@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.hs-rpt-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:1024px){.header-user-info{display:none}.header-user-btn>i{display:none}.dashboard-grid{grid-template-columns:1fr}.dashboard-card-wide{grid-column:span 1}.chart-container{flex-direction:column-reverse;height:auto;gap:16px}.chart-summary{width:100%;flex-direction:row;justify-content:space-between;align-items:center}.chart-bars{height:120px;min-height:120px}}
@media (max-width:900px){.hs-rpt-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){.mobile-menu-btn{display:flex}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0!important;margin-right:0!important;width:100%!important;max-width:100%!important}.header{padding:0 12px 0 56px;height:52px}.header-title{font-size:15px}.content{padding:14px!important}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px}.stat-card .value{font-size:20px}.quick-links{grid-template-columns:repeat(4,1fr)}.search-shortcut-grid{grid-template-columns:repeat(2,1fr)}.header-btn{width:34px;height:34px;font-size:13px}.profile-form .form-row{grid-template-columns:1fr}.settings-item{flex-direction:column;align-items:flex-start;gap:10px}.settings-item .form-control-sm,.settings-item .switch{margin-left:42px}.modal-content,.modal-dialog{width:95%;max-width:none}.stock-actions{flex-direction:column}.stock-actions .btn{width:100%}.header-actions{flex-wrap:wrap}.header-actions .input{width:100%!important}.inv-form-grid{grid-template-columns:1fr 1fr!important}.tax-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tax-tab{white-space:nowrap}.templates-list{grid-template-columns:1fr}.tab-header{flex-direction:column;align-items:flex-start;gap:12px}.tax-line-fields{flex-wrap:wrap}.tax-line-fields .hs-form-group{flex:1 1 100%}.tax-line-fields .hs-form-group:nth-child(2){flex:0 0 80px}.hs-rpt-section-header{flex-direction:column;align-items:flex-start}.hs-rpt-filters{flex-direction:column}.hs-rpt-filter{width:100%}.hs-rpt-summary{flex-direction:column}.hs-rpt-summary-card{min-width:100%}.hs-rpt-pagination{flex-direction:column}[dir="rtl"] .sidebar{transform:translateX(100%)}[dir="rtl"] .sidebar.open{transform:translateX(0)}[dir="rtl"] .header{padding:0 56px 0 12px}[dir="rtl"] .settings-item .form-control-sm,[dir="rtl"] .settings-item .switch{margin-left:0;margin-right:42px}}
@media (max-width:480px){.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:10px}.stat-card .value{font-size:18px}.stat-card .icon,.stat-icon{width:36px;height:36px;font-size:14px;margin-bottom:8px}.quick-links{grid-template-columns:repeat(3,1fr)}.actions{flex-direction:column}.actions .btn{width:100%;justify-content:center}.search-shortcut-grid{grid-template-columns:1fr 1fr}.header-user-btn{padding:4px}.header-dropdown-menu{position:fixed;top:58px;left:10px;right:10px;min-width:auto}.header-dropdown-menu-right{left:10px;right:10px}.profile-header{flex-direction:column;text-align:center}#toast{left:10px;right:10px;bottom:10px;max-width:none}.inv-form-grid{grid-template-columns:1fr!important}.item-detail-header{grid-template-columns:1fr;text-align:center}.item-detail-image,.item-detail-image-placeholder{margin:0 auto}.item-detail-stock{flex-direction:row;justify-content:center}.hs-modal{width:95%;max-height:90vh;border-radius:10px}.hs-modal-header{padding:10px 12px}.hs-modal-body{padding:10px 12px}.hs-modal-footer{padding:8px 12px}.hs-form-row{grid-template-columns:1fr}.hs-profile-header{flex-direction:column;text-align:center}.hs-setting-item{flex-direction:column;align-items:flex-start;gap:8px}.hs-setting-item .hs-toggle{align-self:flex-end}.hs-rpt-grid{grid-template-columns:repeat(2,1fr)}[dir="rtl"] #toast{left:10px;right:10px}}
@media print{.sidebar,.header,.mobile-menu-btn,#toast,#loading,.modal,.modal-overlay,.hs-rpt-header,.hs-rpt-filters,.hs-rpt-section-actions,.hs-rpt-pagination,.hs-rpt-grid,.hs-rpt-chart{display:none!important}.main{margin-left:0!important;margin-right:0!important}.content{padding:0}.card{box-shadow:none;border:1px solid #ddd}.hs-rpt-container,.hs-rpt-section{padding:0!important;border:none!important}.hs-rpt-table{font-size:9px!important}.hs-rpt-table th,.hs-rpt-table td{padding:4px!important}}


/**
 * HSPOS Admin - ZATCA Module
 * Path: hspos/public/css/admin/zatca.css
 * 
 * Ø¥Ù‡Ø¯Ø§Ø¡ Ù…Ù†: Ø§Ù„Ù‡Ø¯ÙˆØ¡ â¤ï¸
 * 
 * ØªØµÙ…ÙŠÙ… Ø¨Ø³ÙŠØ· ÙˆÙ†Ø¸ÙŠÙ Ù…ØªÙˆØ§ÙÙ‚ Ù…Ø¹ admin.css
 */

/* Stats Row */
.zs-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 18px;
}

.zs-stat {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: var(--transition);
}

.zs-stat:hover {
    box-shadow: var(--shadow);
}

.zs-stat-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.zs-stat.total .zs-stat-icon { background: var(--primary-light); color: var(--primary); }
.zs-stat.accepted .zs-stat-icon { background: var(--success-light); color: var(--success); }
.zs-stat.warnings .zs-stat-icon { background: var(--warning-light); color: var(--warning); }
.zs-stat.rejected .zs-stat-icon { background: var(--danger-light); color: var(--danger); }

.zs-stat-num {
    font-size: 22px;
    font-weight: 700;
    color: var(--text);
}

.zs-stat-lbl {
    font-size: 11px;
    color: var(--muted);
}

/* Main Card */
.zs-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.zs-header {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-secondary);
    gap: 6px;
}

.zs-tab {
    padding: 7px 14px;
    border: none;
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--text-secondary);
    font-weight: 500;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
    display: flex;
    align-items: center;
    gap: 6px;
}

.zs-tab:hover { background: var(--card); color: var(--text); }
.zs-tab.active { background: var(--primary); color: #fff; }

.zs-actions {
    margin-right: auto;
    display: flex;
    gap: 8px;
}

.zs-body {
    padding: 16px;
    min-height: 350px;
}

/* Buttons */
.zs-btn {
    padding: 7px 14px;
    border: none;
    border-radius: var(--radius-sm);
    font-weight: 500;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.zs-btn:hover { opacity: 0.9; }
.zs-btn-primary { background: var(--primary); color: #fff; }
.zs-btn-light { background: var(--bg-secondary); color: var(--text-secondary); border: 1px solid var(--border); }
.zs-btn-light:hover { border-color: var(--primary); color: var(--primary); }
.zs-btn-success { background: var(--success); color: #fff; }
.zs-btn-danger { background: var(--danger); color: #fff; }

.zs-btn-sm { padding: 5px 10px; font-size: 11px; }

.zs-btn-icon {
    width: 30px;
    height: 30px;
    padding: 0;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    cursor: pointer;
    transition: var(--transition);
}

.zs-btn-icon:hover {
    border-color: var(--primary);
    color: var(--primary);
}

/* Overview */
.zs-overview {
    display: grid;
    grid-template-columns: 200px 1fr 1fr;
    gap: 16px;
}

.zs-rate-box {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 20px;
    text-align: center;
}

.zs-rate-circle {
    position: relative;
    width: 120px;
    height: 120px;
    margin: 0 auto 12px;
}

.zs-rate-circle svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.zs-rate-circle .bg { fill: none; stroke: var(--border); stroke-width: 10; }
.zs-rate-circle .fg { fill: none; stroke: var(--primary); stroke-width: 10; stroke-linecap: round; }

.zs-rate-txt {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.zs-rate-num { font-size: 26px; font-weight: 700; color: var(--primary); }
.zs-rate-lbl { font-size: 10px; color: var(--muted); }
.zs-rate-sub { font-size: 11px; color: var(--text-secondary); margin-top: 4px; }

/* Type Cards */
.zs-types { display: flex; flex-direction: column; gap: 10px; }

.zs-type {
    flex: 1;
    background: var(--info);
    border-radius: var(--radius);
    padding: 16px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.zs-type.b2b { background: var(--secondary); }
.zs-type-lbl { font-size: 11px; opacity: 0.85; }
.zs-type-num { font-size: 24px; font-weight: 700; }
.zs-type-icon { font-size: 28px; opacity: 0.3; }

/* Quick Actions */
.zs-quick { display: flex; flex-direction: column; gap: 8px; }

.zs-quick-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: var(--transition);
}

.zs-quick-item:hover { border-color: var(--primary); }
.zs-quick-item i { font-size: 14px; width: 18px; text-align: center; }
.zs-quick-item span { font-weight: 500; color: var(--text); font-size: 12px; }

/* Mini Stats */
.zs-mini {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin-top: 16px;
}

.zs-mini-box {
    text-align: center;
    padding: 12px;
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
}

.zs-mini-num { font-size: 18px; font-weight: 700; }
.zs-mini-lbl { font-size: 10px; color: var(--muted); margin-top: 2px; }

/* Companies */
.zs-companies { display: flex; flex-direction: column; gap: 8px; }

.zs-company {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: var(--transition);
}

.zs-company:hover { border-color: var(--primary); }

.zs-company-ico {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.zs-company-ico.on { background: var(--success-light); color: var(--success); }
.zs-company-ico.off { background: var(--warning-light); color: var(--warning); }
.zs-company-ico.none { background: var(--bg-secondary); color: var(--muted); }

.zs-company-info { flex: 1; min-width: 0; }
.zs-company-name { font-weight: 600; color: var(--text); font-size: 13px; }
.zs-company-sub { font-size: 11px; color: var(--muted); }

.zs-company-vat code {
    background: var(--bg-secondary);
    padding: 4px 8px;
    border-radius: var(--radius-xs);
    font-size: 11px;
}

.zs-company-btns { display: flex; gap: 6px; }

/* Badges */
.zs-badge {
    padding: 4px 10px;
    border-radius: var(--radius-full);
    font-size: 10px;
    font-weight: 600;
}

.zs-badge-on { background: var(--success-light); color: var(--success); }
.zs-badge-off { background: var(--warning-light); color: var(--warning); }
.zs-badge-none { background: var(--bg-secondary); color: var(--muted); }
.zs-badge-prod { background: var(--success); color: #fff; }
.zs-badge-sand { background: var(--secondary); color: #fff; }
.zs-badge-b2c { background: var(--info-light); color: var(--info); }
.zs-badge-b2b { background: var(--secondary); color: #fff; }

/* Invoices */
.zs-invoices { display: flex; flex-direction: column; gap: 6px; }

.zs-inv {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: var(--transition);
}

.zs-inv:hover { border-color: var(--primary); }

.zs-inv-type {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 9px;
}

.zs-inv-type.b2c { background: var(--info); }
.zs-inv-type.b2b { background: var(--secondary); }

.zs-inv-info { flex: 1; min-width: 0; }
.zs-inv-name { font-weight: 600; color: var(--text); font-size: 12px; cursor: pointer; }
.zs-inv-name:hover { color: var(--primary); }
.zs-inv-cust { font-size: 10px; color: var(--muted); }

.zs-inv-date, .zs-inv-amt { font-size: 11px; color: var(--text-secondary); min-width: 75px; }
.zs-inv-amt { font-weight: 600; color: var(--text); }
.zs-inv-btns { display: flex; gap: 4px; }

/* Filters */
.zs-filters { display: flex; gap: 5px; flex-wrap: wrap; }

.zs-filter {
    padding: 5px 12px;
    border-radius: var(--radius-full);
    border: 1px solid var(--border);
    background: var(--card);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
}

.zs-filter:hover { border-color: var(--primary); color: var(--primary); }
.zs-filter.active { background: var(--primary); border-color: var(--primary); color: #fff; }
.zs-filter.active.accepted { background: var(--success); border-color: var(--success); }
.zs-filter.active.warnings { background: var(--warning); border-color: var(--warning); }
.zs-filter.active.rejected { background: var(--danger); border-color: var(--danger); }

/* Pagination */
.zs-pager {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.zs-page {
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
}

.zs-page:hover:not(:disabled) { border-color: var(--primary); color: var(--primary); }
.zs-page.current { background: var(--primary); border-color: var(--primary); color: #fff; }
.zs-page:disabled { opacity: 0.4; cursor: not-allowed; }
.zs-page-info { font-size: 10px; color: var(--muted); padding: 0 8px; }

/* Alert */
.zs-alert {
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    margin-bottom: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    background: var(--danger-light);
    color: var(--danger);
}

/* Info */
.zs-phases {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 16px;
}

.zs-phase {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 16px;
    border: 1px solid var(--border);
}

.zs-phase.p1 { background: var(--success-light); border-color: transparent; }
.zs-phase.p2 { background: var(--info-light); border-color: transparent; }

.zs-phase-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.zs-phase-num {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
}

.zs-phase.p1 .zs-phase-num { background: var(--success); }
.zs-phase.p2 .zs-phase-num { background: var(--info); }

.zs-phase h4 { margin: 0; font-size: 13px; color: var(--text); }
.zs-phase small { font-size: 10px; color: var(--muted); }
.zs-phase ul { margin: 0; padding-right: 16px; font-size: 11px; color: var(--text-secondary); line-height: 1.8; }

/* Codes */
.zs-codes {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
}

.zs-codes-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 10px;
}

.zs-code {
    text-align: center;
    padding: 12px;
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
}

.zs-code-ico {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 6px;
    color: #fff;
    font-size: 14px;
}

.zs-code-num { font-size: 18px; font-weight: 700; color: var(--text); }
.zs-code-txt { font-size: 9px; color: var(--muted); }

/* Modal */
.zs-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
}

.zs-modal-box {
    background: var(--card);
    border-radius: var(--radius);
    width: 95%;
    max-width: 700px;
    max-height: 90vh;
    overflow: hidden;
    box-shadow: var(--shadow-xl);
}

.zs-modal-head {
    background: var(--primary);
    padding: 14px 18px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.zs-modal-head h3 { margin: 0; font-size: 14px; font-weight: 600; }

.zs-modal-close {
    background: rgba(255, 255, 255, 0.2);
    border: none;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-sm);
    color: #fff;
    cursor: pointer;
    font-size: 14px;
}

.zs-modal-tabs {
    display: flex;
    background: var(--bg-secondary);
    padding: 8px 12px;
    gap: 5px;
    border-bottom: 1px solid var(--border);
}

.zs-mtab {
    padding: 6px 12px;
    border: none;
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
}

.zs-mtab:hover { background: var(--card); }
.zs-mtab.active { background: var(--primary); color: #fff; }

.zs-modal-body {
    padding: 18px;
    max-height: calc(90vh - 140px);
    overflow-y: auto;
}

.zs-modal-foot {
    padding: 12px 18px;
    background: var(--bg-secondary);
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Form */
.zs-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.zs-form-grp { margin-bottom: 4px; }
.zs-form-grp label { display: block; font-size: 11px; font-weight: 500; color: var(--text); margin-bottom: 4px; }
.zs-form-grp .req { color: var(--danger); }

.zs-input, .zs-select {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card);
    color: var(--text);
    font-size: 12px;
    transition: var(--transition);
}

.zs-input:focus, .zs-select:focus {
    outline: none;
    border-color: var(--primary);
}

/* Toggle */
.zs-toggle-box {
    background: var(--success-light);
    border-radius: var(--radius);
    padding: 12px 14px;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.zs-toggle-title { font-weight: 600; color: var(--success); font-size: 12px; }
.zs-toggle-sub { font-size: 10px; color: var(--text-secondary); }

.zs-switch {
    position: relative;
    width: 40px;
    height: 22px;
}

.zs-switch input { opacity: 0; width: 0; height: 0; }

.zs-switch-track {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--border);
    border-radius: 22px;
    transition: var(--transition);
}

.zs-switch-track::before {
    content: '';
    position: absolute;
    height: 16px;
    width: 16px;
    right: 3px;
    bottom: 3px;
    background: #fff;
    border-radius: 50%;
    transition: var(--transition);
}

.zs-switch input:checked + .zs-switch-track { background: var(--success); }
.zs-switch input:checked + .zs-switch-track::before { transform: translateX(-18px); }

/* Onboarding */
.zs-onboard { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border); }

.zs-onboard-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 12px;
}

.zs-onboard-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px;
    text-align: center;
}

.zs-onboard-card.done { background: var(--primary-light); border-color: var(--primary); }

.zs-onboard-ico {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 6px;
    background: var(--border);
    color: var(--muted);
    font-size: 12px;
}

.zs-onboard-card.done .zs-onboard-ico { background: var(--primary); color: #fff; }
.zs-onboard-lbl { font-weight: 600; font-size: 10px; color: var(--text-secondary); }
.zs-onboard-card.done .zs-onboard-lbl { color: var(--primary); }
.zs-onboard-sts { font-size: 9px; color: var(--muted); }
.zs-onboard-card.done .zs-onboard-sts { color: var(--success); }

.zs-onboard-btns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
}

.zs-onboard-btn {
    padding: 10px;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 500;
    font-size: 10px;
    color: #fff;
    text-align: center;
}

.zs-onboard-btn i { display: block; font-size: 14px; margin-bottom: 3px; }
.zs-onboard-btn.ob { background: var(--secondary); }
.zs-onboard-btn.cp { background: var(--info); }
.zs-onboard-btn.pr { background: var(--success); }

/* ID Box */
.zs-id-box {
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    padding: 10px;
}

.zs-id-box label { display: flex; align-items: center; gap: 5px; margin-bottom: 5px; }
.zs-id-code { background: var(--primary); color: #fff; padding: 2px 5px; border-radius: 4px; font-size: 9px; font-weight: 600; }

/* Empty */
.zs-empty { text-align: center; padding: 40px 20px; }
.zs-empty-ico { width: 60px; height: 60px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; background: var(--bg-secondary); }
.zs-empty-ico i { font-size: 24px; color: var(--muted); }
.zs-empty-ico.primary { background: var(--primary); }
.zs-empty-ico.primary i { color: #fff; }
.zs-empty h4 { margin: 0 0 4px; color: var(--text); font-size: 14px; }
.zs-empty p { margin: 0 0 14px; color: var(--muted); font-size: 11px; }

/* Loading */
.zs-loading { display: flex; justify-content: center; padding: 40px; }
.zs-spinner { width: 32px; height: 32px; border: 3px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: zsSpin 0.7s linear infinite; }
@keyframes zsSpin { to { transform: rotate(360deg); } }

/* Title */
.zs-title { font-size: 11px; font-weight: 600; color: var(--text); margin-bottom: 10px; display: flex; align-items: center; gap: 5px; }
.zs-title i { color: var(--primary); }

/* Info Grid */
.zs-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 12px; }
.zs-info-item { background: var(--bg-secondary); border-radius: var(--radius-sm); padding: 8px; }
.zs-info-lbl { font-size: 9px; color: var(--muted); text-transform: uppercase; margin-bottom: 2px; }
.zs-info-val { font-weight: 600; color: var(--text); font-size: 11px; }

/* Credit */
.zs-credit {
    text-align: center;
    padding: 12px;
    margin-top: 16px;
    font-size: 11px;
    color: var(--muted);
    border-top: 1px solid var(--border);
}

.zs-credit span { color: var(--danger); }

/* Responsive */
@media (max-width: 1024px) {
    .zs-stats { grid-template-columns: repeat(2, 1fr); }
    .zs-overview { grid-template-columns: 1fr; }
    .zs-phases { grid-template-columns: 1fr; }
    .zs-codes-grid { grid-template-columns: repeat(3, 1fr); }
    .zs-form-row { grid-template-columns: 1fr; }
    .zs-onboard-cards, .zs-onboard-btns { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .zs-stats { grid-template-columns: 1fr 1fr; gap: 8px; }
    .zs-header { flex-wrap: wrap; }
    .zs-actions { width: 100%; margin-top: 6px; }
    .zs-codes-grid { grid-template-columns: repeat(2, 1fr); }
    .zs-mini { grid-template-columns: repeat(2, 1fr); }
    .zs-info-grid { grid-template-columns: 1fr; }
}

/**
 * ZATCA Module Styles - Wizard Edition
 * Path: hspos/public/css/admin/zatca.css
 */

/* =============================================
   WIZARD STYLES
   ============================================= */

.zs-modal-wizard {
    max-width: 700px !important;
}

/* Wizard Steps Header */
.zs-wizard-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 24px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
    gap: 0;
    overflow-x: auto;
}

.zs-wizard-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px 16px;
    opacity: 0.5;
    transition: all 0.3s ease;
    position: relative;
    min-width: 80px;
}

.zs-wizard-step.active {
    opacity: 1;
}

.zs-wizard-step.done {
    opacity: 0.8;
}

.zs-wizard-step-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-primary);
    border: 2px solid var(--border-color);
    font-size: 16px;
    color: var(--muted);
    margin-bottom: 8px;
    transition: all 0.3s ease;
}

.zs-wizard-step.active .zs-wizard-step-icon {
    background: var(--primary);
    border-color: var(--primary);
    color: white;
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.3);
}

.zs-wizard-step.done .zs-wizard-step-icon {
    background: var(--success);
    border-color: var(--success);
    color: white;
}

.zs-wizard-step-title {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
    white-space: nowrap;
}

.zs-wizard-step.active .zs-wizard-step-title {
    color: var(--primary);
}

.zs-wizard-step-num {
    display: none;
}

.zs-wizard-line {
    width: 40px;
    height: 2px;
    background: var(--border-color);
    flex-shrink: 0;
}

/* Wizard Content */
.zs-wizard-content {
    padding: 8px 0;
}

.zs-wizard-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--primary);
}

.zs-wizard-header-icon {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.15), rgba(var(--primary-rgb), 0.05));
    color: var(--primary);
    font-size: 24px;
}

.zs-wizard-header h4 {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
}

.zs-wizard-header p {
    margin: 0;
    font-size: 13px;
    color: var(--text-secondary);
}

/* =============================================
   RADIO CARDS (Category Selection)
   ============================================= */

.zs-radio-group {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.zs-radio-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 20px 16px;
    background: var(--bg-secondary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
}

.zs-radio-card:hover {
    border-color: var(--primary);
    background: rgba(var(--primary-rgb), 0.05);
}

.zs-radio-card.selected,
.zs-radio-card:has(input:checked) {
    border-color: var(--primary);
    background: rgba(var(--primary-rgb), 0.1);
}

.zs-radio-card input {
    display: none;
}

.zs-radio-card i {
    font-size: 28px;
    color: var(--muted);
    transition: color 0.2s ease;
}

.zs-radio-card.selected i,
.zs-radio-card:has(input:checked) i {
    color: var(--primary);
}

.zs-radio-card span {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
}

/* =============================================
   ADDRESS PREVIEW
   ============================================= */

.zs-address-preview {
    margin-top: 20px;
    min-height: 150px;
}

.zs-address-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    background: var(--bg-secondary);
    border-radius: var(--radius);
    border: 2px dashed var(--border-color);
    text-align: center;
}

.zs-address-empty i {
    font-size: 40px;
    color: var(--muted);
    margin-bottom: 12px;
}

.zs-address-empty p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 13px;
}

.zs-address-card {
    background: linear-gradient(135deg, var(--bg-secondary), var(--bg-primary));
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    padding: 20px;
}

.zs-address-card-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
}

.zs-address-card-row:last-child {
    border-bottom: none;
}

.zs-address-card-row i {
    width: 24px;
    color: var(--primary);
    text-align: center;
}

.zs-address-card-row span {
    font-size: 14px;
    color: var(--text-primary);
}

/* =============================================
   IDS GRID
   ============================================= */

.zs-ids-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.zs-id-card {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 16px;
    border: 1px solid var(--border-color);
}

.zs-id-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
}

.zs-id-code {
    display: inline-block;
    background: var(--primary);
    color: white;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    font-family: monospace;
}

/* =============================================
   TOGGLE CARD
   ============================================= */

.zs-toggle-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.1), rgba(var(--primary-rgb), 0.05));
    border: 2px solid rgba(var(--primary-rgb), 0.2);
    border-radius: var(--radius);
    margin-bottom: 20px;
}

.zs-toggle-info {
    display: flex;
    align-items: center;
    gap: 16px;
}

.zs-toggle-info i {
    font-size: 28px;
    color: var(--primary);
}

.zs-toggle-info strong {
    display: block;
    font-size: 15px;
    margin-bottom: 4px;
}

.zs-toggle-info p {
    margin: 0;
    font-size: 12px;
    color: var(--text-secondary);
}

/* =============================================
   ONBOARDING TIMELINE
   ============================================= */

.zs-onboard-timeline {
    position: relative;
    padding-right: 20px;
}

.zs-onboard-timeline::before {
    content: '';
    position: absolute;
    right: 31px;
    top: 24px;
    bottom: 24px;
    width: 2px;
    background: var(--border-color);
}

.zs-onboard-item {
    display: flex;
    gap: 16px;
    padding: 16px 0;
    position: relative;
}

.zs-onboard-item.disabled {
    opacity: 0.5;
    pointer-events: none;
}

.zs-onboard-item-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    border: 2px solid var(--border-color);
    color: var(--muted);
    font-size: 16px;
    flex-shrink: 0;
    z-index: 1;
}

.zs-onboard-item.done .zs-onboard-item-icon {
    background: var(--success);
    border-color: var(--success);
    color: white;
}

.zs-onboard-item-content {
    flex: 1;
}

.zs-onboard-item-content h5 {
    margin: 0 0 4px;
    font-size: 15px;
    font-weight: 600;
}

.zs-onboard-item-content p {
    margin: 0 0 12px;
    font-size: 12px;
    color: var(--text-secondary);
}

/* =============================================
   SUCCESS BANNER
   ============================================= */

.zs-success-banner {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: linear-gradient(135deg, rgba(var(--success-rgb), 0.15), rgba(var(--success-rgb), 0.05));
    border: 2px solid var(--success);
    border-radius: var(--radius);
    margin-top: 24px;
}

.zs-success-banner i {
    font-size: 40px;
    color: var(--success);
}

.zs-success-banner strong {
    display: block;
    font-size: 16px;
    color: var(--success);
    margin-bottom: 4px;
}

/* =============================================
   INFO CARD
   ============================================= */

.zs-info-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 20px;
    background: rgba(var(--info-rgb), 0.1);
    border: 1px solid rgba(var(--info-rgb), 0.3);
    border-radius: var(--radius);
    color: var(--info);
}

.zs-info-card i {
    font-size: 20px;
    margin-top: 2px;
}

.zs-info-card p {
    margin: 0;
    font-size: 13px;
}

/* =============================================
   LINK BUTTON
   ============================================= */

.zs-link-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    padding: 0;
    border: none;
    background: none;
    color: var(--primary);
    font-size: 13px;
    cursor: pointer;
    transition: color 0.2s ease;
}

.zs-link-btn:hover {
    color: var(--primary-dark);
    text-decoration: underline;
}

/* =============================================
   OUTLINE BUTTON
   ============================================= */

.zs-btn-outline {
    background: transparent;
    border: 2px solid var(--primary);
    color: var(--primary);
}

.zs-btn-outline:hover {
    background: var(--primary);
    color: white;
}

/* =============================================
   SMALL MODAL (Address)
   ============================================= */

.zs-modal-sm .zs-modal-box {
    max-width: 500px !important;
}

/* =============================================
   PHASE BADGES
   ============================================= */

.zs-phase-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-left: 8px;
}

.zs-phase-badge.p1 {
    background: linear-gradient(135deg, #06b6d4, #0891b2);
    color: white;
}

.zs-phase-badge.p2 {
    background: linear-gradient(135deg, #8b5cf6, #6d28d9);
    color: white;
}

/* =============================================
   BADGE VARIANTS
   ============================================= */

.zs-badge-phase1 { background: rgba(6, 182, 212, 0.15) !important; color: #0891b2 !important; }
.zs-badge-phase2 { background: rgba(139, 92, 246, 0.15) !important; color: #7c3aed !important; }

/* =============================================
   TYPE CARDS (Overview)
   ============================================= */

.zs-type.phase1 {
    background: linear-gradient(135deg, rgba(6, 182, 212, 0.1), rgba(8, 145, 178, 0.05));
    border-color: rgba(6, 182, 212, 0.2);
}

.zs-type.phase1 .zs-type-icon { color: #0891b2; }

.zs-type.phase2 {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.1), rgba(109, 40, 217, 0.05));
    border-color: rgba(139, 92, 246, 0.2);
}

.zs-type.phase2 .zs-type-icon { color: #7c3aed; }

/* =============================================
   PHASE CARDS (Info)
   ============================================= */

.zs-phases-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

.zs-phase-card {
    background: var(--bg-primary);
    border-radius: var(--radius);
    padding: 24px;
    border: 2px solid var(--border-color);
}

.zs-phase-card.p1 { border-color: rgba(6, 182, 212, 0.3); }
.zs-phase-card.p2 { border-color: rgba(139, 92, 246, 0.3); }

.zs-phase-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
}

.zs-phase-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}

.zs-phase-card.p1 .zs-phase-icon {
    background: rgba(6, 182, 212, 0.15);
    color: #0891b2;
}

.zs-phase-card.p2 .zs-phase-icon {
    background: rgba(139, 92, 246, 0.15);
    color: #7c3aed;
}

.zs-phase-header h3 {
    margin: 0;
    font-size: 18px;
}

.zs-phase-header span {
    font-size: 12px;
    color: var(--muted);
}

.zs-phase-card ul {
    margin: 0 0 20px;
    padding: 0;
    list-style: none;
}

.zs-phase-card li {
    padding: 8px 0;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--text-secondary);
}

.zs-phase-card li i { color: var(--success); }

/* =============================================
   BUTTON VARIANTS
   ============================================= */

.zs-btn-secondary {
    background: linear-gradient(135deg, #06b6d4, #0891b2);
    color: white;
}

.zs-btn-secondary:hover {
    background: linear-gradient(135deg, #0891b2, #0e7490);
}

.zs-btn-success {
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
}

.zs-btn-success:hover {
    background: linear-gradient(135deg, #059669, #047857);
}

.zs-btn-info {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    color: white;
}

.zs-btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: white;
}

.zs-btn-group {
    display: flex;
    gap: 8px;
}

.zs-btn-group-sm {
    display: flex;
    gap: 6px;
}

/* =============================================
   RTL SUPPORT
   ============================================= */

[dir="rtl"] .zs-wizard-steps {
    flex-direction: row-reverse;
}

[dir="rtl"] .zs-onboard-timeline::before {
    right: auto;
    left: 31px;
}

[dir="rtl"] .zs-onboard-timeline {
    padding-right: 0;
    padding-left: 20px;
}

[dir="rtl"] .zs-phase-badge {
    margin-left: 0;
    margin-right: 8px;
}

[dir="rtl"] .zs-modal-foot {
    flex-direction: row-reverse;
}

[dir="rtl"] .zs-modal-foot .fa-arrow-left {
    transform: rotate(180deg);
}

[dir="rtl"] .zs-modal-foot .fa-arrow-right {
    transform: rotate(180deg);
}

/* =============================================
   RESPONSIVE
   ============================================= */

@media (max-width: 768px) {
    .zs-modal-wizard {
        max-width: 95% !important;
    }
    
    .zs-wizard-steps {
        padding: 12px;
        gap: 0;
    }
    
    .zs-wizard-step {
        padding: 6px 8px;
        min-width: 60px;
    }
    
    .zs-wizard-step-icon {
        width: 36px;
        height: 36px;
        font-size: 14px;
    }
    
    .zs-wizard-step-title {
        font-size: 9px;
    }
    
    .zs-wizard-line {
        width: 20px;
    }
    
    .zs-radio-group {
        grid-template-columns: 1fr;
    }
    
    .zs-ids-grid {
        grid-template-columns: 1fr;
    }
    
    .zs-form-row {
        grid-template-columns: 1fr;
    }
    
    .zs-toggle-card {
        flex-direction: column;
        text-align: center;
        gap: 16px;
    }
    
    .zs-toggle-info {
        flex-direction: column;
    }
}
/* =============================================
   FRAPPE MODAL/DIALOG FIXES
   ============================================= */

/* Fix Frappe confirm/alert dialogs */
.modal-backdrop,
.frappe-control .modal-backdrop,
body > .modal-backdrop {
    z-index: 10040 !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    opacity: 1 !important;
}

/* Frappe Bootstrap modal fixes */
body > .modal,
.modal.fade.show,
.modal.fade.in,
.modal.in,
.frappe-control .modal.fade.show,
.frappe-control .modal.fade.in {
    z-index: 10050 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: rgba(0, 0, 0, 0.5) !important;
    pointer-events: auto !important;
}

body > .modal .modal-dialog,
.modal.fade.show .modal-dialog,
.modal.fade.in .modal-dialog,
.modal.in .modal-dialog {
    z-index: 10051 !important;
    pointer-events: auto !important;
    transform: none !important;
    margin: auto !important;
    max-width: 500px;
}

body > .modal .modal-content,
.modal.fade.show .modal-content,
.modal.fade.in .modal-content,
.modal.in .modal-content {
    pointer-events: auto !important;
    background: var(--card) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-xl) !important;
    border: 1px solid var(--border) !important;
    max-width: 100%;
}

/* Ensure modal buttons are clickable */
body > .modal .modal-footer,
body > .modal .modal-body,
body > .modal .modal-header,
body > .modal .btn,
body > .modal button,
.modal.fade.show .btn,
.modal.fade.in .btn,
.modal.in .btn {
    pointer-events: auto !important;
    position: relative !important;
    z-index: 1 !important;
    cursor: pointer !important;
}

/* Frappe specific classes */
.msgprint-dialog,
.frappe-confirm,
[data-modal="true"],
.modal[role="dialog"] {
    z-index: 10050 !important;
    pointer-events: auto !important;
}

/* Our custom HSPOS modals - lower z-index */
.modal-invoice,
#new-invoice-modal,
#payment-modal,
#invoice-details-modal,
#new-customer-modal,
#new-quotation-modal,
#quotation-details-modal,
#return-modal,
#edit-customer-modal,
#unpaid-invoices-modal {
    z-index: 1050 !important;
}

.modal-invoice.show,
#new-invoice-modal.show,
#payment-modal.show,
#invoice-details-modal.show {
    z-index: 1050 !important;
    background: rgba(0, 0, 0, 0.5) !important;
}

/* Quick Add modals - must appear above invoice modal */
#purch-new-supplier-modal,
#purch-quick-add-item-modal {
    z-index: 1150 !important;
}
#purch-new-supplier-modal.show,
#purch-quick-add-item-modal.show {
    z-index: 1150 !important;
    background: rgba(0, 0, 0, 0.5) !important;
}

/* Product Bundle Suggestions Dropdown */
.bundle-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    z-index: 100;
    max-height: 200px;
    overflow-y: auto;
}
.bundle-suggestion-item {
    padding: 8px 12px;
    cursor: pointer;
    font-size: 13px;
    border-bottom: 1px solid var(--border);
}
.bundle-suggestion-item:last-child { border-bottom: none; }
.bundle-suggestion-item:hover { background: var(--bg-secondary); }