:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #3b82f6;--primary-soft: #eff6ff;--primary-border: #bfdbfe;--success: #16a34a;--success-soft: #f0fdf4;--success-light: #22c55e;--success-light-soft: #dcfce7;--warning: #d97706;--warning-soft: #fffbeb;--danger: #dc2626;--danger-soft: #fef2f2;--info: #0891b2;--info-soft: #ecfeff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--surface: #ffffff;--surface-alt: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--sidebar-w: 260px;--sidebar-w-col: 72px;--topbar-h: 64px;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);--shadow-primary: 0 4px 15px rgba(37,99,235,.35);--ease: cubic-bezier(.4, 0, .2, 1);--duration: .2s;--duration-lg: .35s;--font: "Cairo", "Tajawal", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font);background:var(--gray-100);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}[dir=ltr] body,[dir=ltr]{font-family:Inter,Roboto,system-ui,sans-serif}[dir=ltr] .sidebar{right:auto;left:0}[dir=ltr] .sidebar.open{transform:translate(0)!important}@media (max-width: 1024px){[dir=ltr] .sidebar{right:auto;left:0;transform:translate(-110%)}}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:700}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-100{width:100%}.text-center{text-align:center}.text-end{text-align:left}.fw-bold{font-weight:700}.fw-semibold{font-weight:600}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:var(--radius)}.rounded-full{border-radius:var(--radius-full)}#global-loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:var(--primary-soft);display:grid;place-items:center;transition:opacity var(--duration-lg) var(--ease)}#global-loader .loader-content{text-align:center}#global-loader .loader-icon{width:72px;height:72px;margin:0 auto 1.5rem;background:var(--primary);border-radius:var(--radius-xl);display:grid;place-items:center;box-shadow:var(--shadow-primary);animation:loader-pulse 2s ease-in-out infinite}#global-loader .loader-icon i{color:#fff;font-size:2rem}#global-loader p{color:var(--text-secondary);font-size:var(--text-sm);margin-top:.5rem}@keyframes loader-pulse{0%,to{transform:scale(1);box-shadow:var(--shadow-primary)}50%{transform:scale(1.07);box-shadow:0 8px 25px #2563eb80}}.spinner{width:36px;height:36px;border:3px solid var(--primary-border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(360deg)}}#login-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#1e3a8a,#1d4ed8,#2563eb);padding:1rem}.login-card{background:var(--surface);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:slide-in .5s var(--ease) both}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-brand{text-align:center;margin-bottom:2rem}.login-brand .brand-icon{width:72px;height:72px;margin:0 auto 1rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-lg);display:grid;place-items:center;box-shadow:var(--shadow-primary)}.login-brand .brand-icon i{color:#fff;font-size:1.8rem}.login-brand h1{font-size:var(--text-2xl);color:var(--text-primary)}.login-brand p{color:var(--text-muted);font-size:var(--text-sm);margin-top:.25rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.input-wrap{position:relative}.input-wrap i{position:absolute;top:50%;transform:translateY(-50%);inset-inline-end:1rem;color:var(--text-muted);font-size:var(--text-sm);pointer-events:none}.input-wrap .toggle-pass{position:absolute;top:50%;transform:translateY(-50%);inset-inline-start:1rem;color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;pointer-events:all;background:none;border:none}.form-input{width:100%;padding-block:.75rem;padding-inline-end:2.75rem;padding-inline-start:1rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:var(--text-base);font-family:var(--font);background:var(--gray-50);color:var(--text-primary);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);outline:none}.form-input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}.form-input.has-icon{padding-inline-end:2.75rem}.form-input.has-action{padding-inline-start:2.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:var(--radius);font-size:var(--text-sm);font-weight:700;font-family:var(--font);border:1.5px solid transparent;cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap;line-height:1}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary-dark);box-shadow:0 2px 8px #2563eb4d}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-outline{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn-outline:hover:not(:disabled){background:var(--gray-100);border-color:var(--border-strong);color:var(--text-primary)}.btn-outline-primary{background:transparent;color:var(--primary);border-color:var(--primary-border)}.btn-outline-primary:hover:not(:disabled){background:var(--primary-soft)}.btn-outline-danger{background:transparent;color:var(--danger);border-color:#fecaca}.btn-outline-danger:hover:not(:disabled){background:var(--danger-soft)}.btn-success{background:var(--success);color:#fff;border-color:#15803d;box-shadow:0 2px 8px #16a34a40}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff;border-color:#b91c1c;box-shadow:0 2px 8px #dc262640}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-warning{background:var(--warning);color:#fff;border-color:#b45309}.btn-warning:hover:not(:disabled){background:#b45309}.btn-light{background:var(--gray-100);color:var(--text-secondary);border-color:var(--border)}.btn-light:hover:not(:disabled){background:var(--gray-200)}.btn-lg{padding:.875rem 1.75rem;font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:.4rem .8rem;font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-icon{padding:.6rem;width:38px;height:38px}.btn-w-full{width:100%}#dashboard-shell{display:flex;flex-direction:row;min-height:100vh;background:var(--gray-100);width:100%}.sidebar{position:sticky;top:0;height:100vh;width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-inline-end:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;transition:width var(--duration-lg) var(--ease);z-index:100}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem;position:relative}.sidebar-brand-text{flex:1;min-width:0;overflow:hidden}.sidebar-logo{width:40px;height:40px;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius);display:grid;place-items:center;box-shadow:var(--shadow-primary)}.sidebar-logo i{color:#fff;font-size:1.1rem}.sidebar-brand{font-size:var(--text-lg);font-weight:800;color:var(--primary);line-height:1;white-space:nowrap}.sidebar-collapse-btn{width:28px;height:28px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:all var(--duration) var(--ease);font-size:.7rem}.sidebar-collapse-btn:hover{background:var(--primary-soft);border-color:var(--primary-border);color:var(--primary)}[dir=rtl] .sidebar-collapse-btn i{transform:rotate(180deg)}.sidebar.collapsed{width:64px}.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .sidebar-user .sidebar-user-name,.sidebar.collapsed .sidebar-user .sidebar-user-role{display:none}.sidebar.collapsed .sidebar-user{justify-content:center;padding:.75rem .5rem}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:.65rem 0}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .nav-item i{width:auto;font-size:1.1rem}.sidebar.collapsed .sidebar-footer .nav-item span{display:none}.sidebar.collapsed .sidebar-footer{padding:.5rem}.sidebar.collapsed .sidebar-collapse-btn i,[dir=rtl] .sidebar.collapsed .sidebar-collapse-btn i{transform:rotate(0)!important}[dir=ltr] .sidebar.collapsed .sidebar-collapse-btn i{transform:rotate(180deg)!important}.sidebar.collapsed .sidebar-header{justify-content:center;gap:0;padding:1rem .5rem;flex-wrap:wrap}.sidebar.collapsed .sidebar-logo{margin:0}.sidebar.collapsed .sidebar-collapse-btn{margin-top:.5rem}.sidebar-user{padding:1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.sidebar-avatar{width:42px;height:42px;border-radius:var(--radius-full);background:var(--primary-soft);flex-shrink:0;display:grid;place-items:center;overflow:hidden;border:2px solid var(--primary-border)}.sidebar-avatar i{color:var(--primary);font-size:1.1rem}.sidebar-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-user-name{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.sidebar-user-role{font-size:var(--text-xs);color:var(--text-muted)}.sidebar-nav{flex:1;overflow-y:auto;padding:.75rem;scrollbar-width:thin;scrollbar-color:var(--gray-200) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:4px}.nav-label{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.5rem .75rem .25rem;margin-top:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .875rem;border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease);border:none;background:none;width:100%;text-align:start;position:relative;white-space:nowrap}.nav-item i{width:20px;text-align:center;flex-shrink:0;font-size:1rem}.nav-item:hover{background:var(--gray-100);color:var(--primary)}.nav-item.active{background:var(--primary-soft);color:var(--primary)}.nav-item.active:before{content:"";position:absolute;inset-inline-start:0;top:20%;bottom:20%;width:3px;background:var(--primary);border-radius:3px}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:90;box-shadow:var(--shadow-sm)}.topbar-start{display:flex;align-items:center;gap:1rem}.topbar-end{display:flex;align-items:center;gap:.75rem}.page-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.notif-badge{position:absolute;top:-4px;inset-inline-start:-4px;min-width:18px;height:18px;border-radius:var(--radius-full);background:var(--danger);color:#fff;font-size:10px;font-weight:800;line-height:18px;text-align:center;padding:0 4px}.main-content{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden;min-height:100vh}.content-area{flex:1;overflow-y:auto;padding:1.5rem}.view{animation:fade-in .25s var(--ease) both}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-pad{padding:1.5rem}.card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem}.card-header h3{font-size:var(--text-base);font-weight:700}.card-body{padding:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm);transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.stat-icon{width:52px;height:52px;flex-shrink:0;border-radius:var(--radius);display:grid;place-items:center;font-size:1.3rem}.stat-icon.primary{background:var(--primary-soft);color:var(--primary)}.stat-icon.success{background:var(--success-soft);color:var(--success)}.stat-icon.warning{background:var(--warning-soft);color:var(--warning)}.stat-icon.danger{background:var(--danger-soft);color:var(--danger)}.stat-icon.info{background:var(--info-soft);color:var(--info)}.stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);margin-bottom:.25rem}.stat-value{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table thead th{background:var(--gray-50);padding:.75rem 1rem;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-align:start;border-bottom:1px solid var(--border);white-space:nowrap}.data-table tbody td{padding:.875rem 1rem;border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--duration) var(--ease)}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:var(--primary-soft)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .65rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;white-space:nowrap}.badge-primary{background:var(--primary-soft);color:var(--primary)}.badge-success{background:var(--success-soft);color:var(--success)}.badge-success-light{background:var(--success-light-soft);color:var(--success-light)}.badge-warning{background:var(--warning-soft);color:var(--warning)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-info{background:var(--info-soft);color:var(--info)}.badge-gray{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--border)}.filter-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;padding-bottom:.5rem}.filter-tab{padding:.4rem 1rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease)}.filter-tab:hover{border-color:var(--primary-border);color:var(--primary);background:var(--primary-soft)}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.filter-tab.tab-danger:hover{border-color:#fecaca;color:var(--danger);background:var(--danger-soft)}.filter-tab.tab-danger.active{background:var(--danger);color:#fff;border-color:#b91c1c}.filter-tab.tab-warning:hover{border-color:#fde68a;color:var(--warning);background:var(--warning-soft)}.filter-tab.tab-warning.active{background:var(--warning);color:#fff;border-color:#b45309}.filter-tab.tab-success:hover{border-color:#bbf7d0;color:var(--success);background:var(--success-soft)}.filter-tab.tab-success.active{background:var(--success);color:#fff;border-color:#15803d}.filter-tab.tab-success-light:hover{border-color:#86efac;color:var(--success-light);background:var(--success-light-soft)}.filter-tab.tab-success-light.active{background:var(--success-light);color:#fff;border-color:#16a34a}.filter-tab.tab-info:hover{border-color:#a5f3fc;color:var(--info);background:var(--info-soft)}.filter-tab.tab-info.active{background:var(--info);color:#fff;border-color:#0e7490}.filter-tab.tab-gray:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--gray-100)}.filter-tab.tab-gray.active{background:var(--gray-500);color:#fff;border-color:var(--gray-700)}.search-wrap{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.5rem 1rem;min-width:220px;transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.search-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.search-wrap i{color:var(--text-muted);font-size:var(--text-sm);flex-shrink:0}.search-wrap input{border:none;outline:none;background:transparent;width:100%;font-size:var(--text-sm);font-family:var(--font);color:var(--text-primary)}.search-wrap input::placeholder{color:var(--text-muted)}#toast-container{position:fixed;bottom:1.5rem;left:1.5rem;display:flex;flex-direction:column-reverse;gap:.5rem;z-index:99998}.toast{background:var(--gray-900);color:#fff;padding:.875rem 1.25rem;border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);max-width:340px;animation:toast-in .3s var(--ease) both}.toast.removing{animation:toast-out .3s var(--ease) both}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning)}.toast-info{background:var(--info)}@keyframes toast-in{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}#workspace-loader{position:fixed;top:0;right:0;bottom:0;left:0;background:#f8fafcbf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:grid;place-items:center}.ws-loader-pill{background:var(--surface);border:1.5px solid var(--primary-border);border-radius:var(--radius-full);padding:.875rem 1.75rem;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);font-weight:700;color:var(--primary);font-size:var(--text-sm)}.ws-loader-pill i{animation:spin .7s linear infinite}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:grid;place-items:center;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:460px;animation:modal-in .25s var(--ease) both}.modal-lg{max-width:640px}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:var(--text-lg);font-weight:700}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.875rem}.service-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;cursor:pointer;transition:all var(--duration) var(--ease);position:relative}.service-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--primary);opacity:0;pointer-events:none;transition:opacity var(--duration) var(--ease)}.service-card:hover{border-color:var(--primary-border);transform:translateY(-2px);box-shadow:var(--shadow)}.service-card.selected{border-color:var(--primary);background:var(--primary-soft)}.service-card.selected .service-card-icon{background:var(--primary);color:#fff}.service-card-top{display:flex;align-items:center;gap:1rem;width:100%}.service-card-bottom{display:flex;align-items:center;justify-content:space-between;width:100%;padding-top:.75rem;border-top:1px dashed var(--border);position:relative;z-index:5}.service-card-icon{width:44px;height:44px;border-radius:var(--radius);flex-shrink:0;background:var(--surface-alt);color:var(--primary);display:grid;place-items:center;font-size:1.1rem;transition:all var(--duration) var(--ease)}.service-card .service-card-icon{border:1px solid var(--border)}.service-card.selected .service-card-icon{border-color:var(--primary-dark)}.service-card-name{font-weight:700;font-size:var(--text-sm);white-space:normal;word-break:break-word;line-height:1.4;color:var(--text-primary)}.service-card-price{font-size:var(--text-sm);font-weight:700;color:var(--primary);margin-top:.15rem}.service-card-qty{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-full);padding:.35rem .75rem;font-size:var(--text-base);font-weight:800;flex-shrink:0;box-shadow:var(--shadow-sm);color:var(--primary-dark);position:relative;z-index:10}.service-card-qty button{width:34px;height:34px;border-radius:var(--radius-full);background:var(--gray-50);color:var(--text-secondary);border:1px solid var(--border);display:grid;place-items:center;font-size:1rem;transition:all var(--duration) var(--ease);cursor:pointer}.service-card-qty button:hover{background:var(--primary);color:#fff;border-color:var(--primary-dark);transform:scale(1.05)}.service-card-qty button:active{transform:scale(.95)}.service-card-qty span{min-width:28px;text-align:center}.notes-list{display:flex;flex-direction:column;gap:.875rem}.note-item{display:flex;gap:.75rem}.note-avatar{width:32px;height:32px;border-radius:var(--radius-full);flex-shrink:0;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-size:var(--text-xs);font-weight:700}.note-bubble{background:var(--gray-50);border:1px solid var(--border);border-radius:0 var(--radius) var(--radius) var(--radius);padding:.75rem 1rem;flex:1}.note-bubble .note-meta{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:.4rem}.note-bubble .note-text{font-size:var(--text-sm)}.note-attachment{display:inline-flex;align-items:center;gap:.4rem;margin-top:.5rem;padding:.3rem .75rem;border-radius:var(--radius-full);background:var(--primary-soft);color:var(--primary);font-size:var(--text-xs);font-weight:600;text-decoration:none}.quick-feed{display:flex;flex-direction:column;gap:.5rem;max-height:160px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gray-200) transparent}.feed-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .875rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:all var(--duration) var(--ease);font-size:var(--text-sm)}.feed-item:hover{background:var(--primary-soft);border-color:var(--primary-border)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.summary-box{background:var(--primary-soft);border:1.5px solid var(--primary-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center}.summary-box .total-amount{font-size:2.5rem;font-weight:800;color:var(--primary);line-height:1}.summary-row{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--text-secondary);margin-top:.5rem}@media (min-width: 1200px){:root{--sidebar-w: 268px}.content-area{padding:1.75rem}.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1199px){:root{--sidebar-w: 240px}.stats-grid,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (min-width: 769px) and (max-width: 1024px){:root{--sidebar-w: 200px}.sidebar{overflow-x:hidden}.sidebar-brand,.sidebar-brand-sub{font-size:var(--text-sm)}.nav-item{padding:.6rem .625rem;font-size:var(--text-xs);gap:.5rem}.nav-item i{font-size:.9rem}.sidebar-user{padding:.75rem;gap:.5rem}.sidebar-avatar{width:36px;height:36px}.sidebar-user-name{font-size:var(--text-xs)}.sidebar-user-role{font-size:10px}.sidebar-header{padding:1rem .875rem}.content-area{padding:1rem}.grid-2,.grid-3{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.topbar{padding:0 1rem}.topbar-end{gap:.4rem}.page-title{font-size:var(--text-base)}.filter-tabs{flex-wrap:nowrap;overflow-x:auto}#menu-toggle{display:flex!important}}@media (max-width: 1024px){.sidebar{position:fixed;inset-block:0;inset-inline-start:auto;inset-inline-end:0;right:0;top:0;bottom:0;width:260px!important;height:100dvh;transform:translate(110%);transition:transform var(--duration-lg) var(--ease);z-index:500;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:499;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.show{display:block}#dashboard-shell{flex-direction:row}.main-content{width:100%;flex:1}#menu-toggle{display:flex!important}}@media (max-width: 768px){.main-content{width:100%}.content-area{padding:1rem}#menu-toggle{display:flex!important}.grid-2,.grid-3{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:repeat(2,1fr)}.table-wrap{border-radius:var(--radius)}.topbar{padding:0 1rem}.topbar-end{gap:.5rem}.page-title{font-size:var(--text-base)}.card-pad,.card-body{padding:1.25rem}.card-header{padding:.875rem 1.25rem;flex-wrap:wrap;gap:.5rem}.filter-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.25rem}.filter-tabs::-webkit-scrollbar{height:3px}.filter-tabs::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.summary-box .total-amount{font-size:2rem}.modal{max-width:100%!important;margin:.5rem;border-radius:var(--radius-lg)}.modal-body{padding:1.25rem}.modal-backdrop{align-items:flex-end;padding:0 0 .5rem}.services-grid{grid-template-columns:1fr}.quick-feed{max-height:200px}.profile-avatar-wrap{flex-direction:column;align-items:flex-start;margin-top:-30px}.dropdown-card{min-width:200px}#detail-actions{flex-direction:column}#detail-actions .btn{width:100%;justify-content:center}}@media (max-width: 480px){:root{--topbar-h: 56px;--sidebar-w: 280px}.login-card{padding:1.5rem;margin:.75rem;border-radius:var(--radius-lg)}.login-brand .brand-icon{width:60px;height:60px}.login-brand h1{font-size:var(--text-xl)}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon{width:44px;height:44px;font-size:1.1rem}.stat-value{font-size:var(--text-xl)}.card-pad,.card-body{padding:1rem}.topbar{padding:0 .75rem}.page-title{font-size:var(--text-sm);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table thead th,.data-table tbody td{padding:.625rem .75rem}.filter-tab{font-size:var(--text-xs);padding:.35rem .7rem}.search-wrap{min-width:0;width:100%}.flex.gap-3.flex-wrap,.flex.gap-2.flex-wrap{gap:.5rem}.content-area{padding:.75rem}#detail-actions{gap:.5rem}.badge{font-size:10px;padding:.2rem .5rem}#toast-container{left:.5rem;right:.5rem;bottom:.75rem}.toast{max-width:100%}.empty-state{padding:2.5rem 1rem}.empty-state i{font-size:3rem}}@media (min-width: 1440px){:root{--sidebar-w: 280px}.content-area{padding:2rem}.stats-grid{grid-template-columns:repeat(4,1fr)}.grid-3{gap:1.5rem}}@media (min-width: 769px){#menu-toggle,.sidebar-overlay{display:none!important}}*{max-width:100%}img,canvas,video{max-width:100%;height:auto}.data-table{min-width:500px}.services-grid .service-card{min-width:0}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state i{font-size:4rem;margin-bottom:1rem;opacity:.3}.empty-state h3{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:.5rem}.dropdown-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:.75rem;min-width:220px;position:absolute;top:calc(100% + .5rem);left:0;z-index:500}.dropdown-title{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-align:center;padding:.25rem .5rem .75rem;border-bottom:1px solid var(--border);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.06em}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .875rem;border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;cursor:pointer;width:100%;border:none;background:none;transition:background var(--duration) var(--ease);text-align:right}.dropdown-item:hover{background:var(--gray-100)}.profile-cover{height:100px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.profile-avatar-wrap{margin-top:-40px;padding:0 1.5rem 1.5rem;display:flex;align-items:flex-end;gap:1.25rem}.profile-avatar{width:80px;height:80px;border-radius:var(--radius-full);border:4px solid var(--surface);box-shadow:var(--shadow);background:var(--primary-soft);overflow:hidden;display:grid;place-items:center;flex-shrink:0}.profile-avatar i{font-size:2.5rem;color:var(--primary)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{color:var(--primary)}.notif-item{display:flex;gap:.75rem;padding:.75rem;border-radius:var(--radius);cursor:pointer;transition:background var(--duration) var(--ease)}.notif-item:hover{background:var(--gray-50)}.notif-item:not(:last-child){border-bottom:1px solid var(--gray-100)}.notif-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--primary);flex-shrink:0;margin-top:.35rem}.me-1{margin-inline-end:.25rem}.me-2{margin-inline-end:.5rem}.me-3{margin-inline-end:.75rem}.ms-1{margin-inline-start:.25rem}.ms-2{margin-inline-start:.5rem}.ms-3{margin-inline-start:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.my-auto{margin-top:auto;margin-bottom:auto}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:1rem;padding-bottom:1rem}.d-none{display:none!important}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.d-inline{display:inline}.d-inline-flex{display:inline-flex}.border{border:1px solid var(--border)}.border-top{border-top:1px solid var(--border)}.border-bottom{border-bottom:1px solid var(--border)}.fs-1{font-size:2.5rem}.fs-2{font-size:2rem}.fs-3{font-size:1.75rem}.fs-4{font-size:1.5rem}.fs-5{font-size:1.25rem}.fs-6{font-size:1rem}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.w-auto{width:auto}.h-100{height:100%}.overflow-hidden{overflow:hidden}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-nowrap{white-space:nowrap}.text-wrap{white-space:normal}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.flex-grow-0{flex-grow:0}.align-items-start{align-items:flex-start}.align-items-end{align-items:flex-end}.align-items-center{align-items:center}.justify-content-end{justify-content:flex-end}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.gap-0{gap:0}.gap-5{gap:1.25rem}.cursor-pointer{cursor:pointer}.user-select-none{-webkit-user-select:none;user-select:none}.position-relative{position:relative}.position-absolute{position:absolute}.min-w-0{min-width:0}small,.small{font-size:.875em}.link-primary{color:var(--primary);text-decoration:underline}
