:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#dbeafe;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--gray-50:#f9fafb;--gray-100:#f8fafc;--gray-150:#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;--white:#fff;--shadow-sm:0 1px 2px 0 #0f172a0f;--shadow:0 1px 3px 0 #0f172a14, 0 1px 2px -1px #0f172a0f;--shadow-md:0 4px 6px -1px #0f16271a, 0 2px 4px -2px #0f172a14;--shadow-lg:0 10px 15px -3px #0f172a1a, 0 4px 6px -4px #0f172a14;--shadow-xl:0 20px 25px -5px #0f172a1a, 0 8px 10px -6px #0f172a0d;--radius:12px;--radius-sm:10px;--sidebar-width:260px;--header-height:60px;--border-color:#e2e8f0;--font-family:"Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Inter", sans-serif;--font-size:14px;font-family:var(--font-family);font-size:var(--font-size);color:var(--gray-800);background:var(--gray-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{background:var(--gray-100)}.login-container{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:var(--white);box-shadow:var(--shadow-lg);border-radius:16px;width:100%;max-width:420px;padding:48px 40px}.login-box h1{text-align:center;color:var(--gray-900);margin-bottom:8px;font-size:28px}.login-box .subtitle{text-align:center;color:var(--gray-500);margin-bottom:32px;font-size:14px}@media (width<=480px){.login-box{padding:32px 24px}.login-box h1{font-size:24px}}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;min-height:40px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--white);box-shadow:0 2px 4px #2563eb33}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.btn-secondary{background:var(--gray-150);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200);transform:translateY(-1px)}.btn-success{background:var(--success);color:var(--white)}.btn-success:hover{background:#059669;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-accent{color:var(--white);background:linear-gradient(135deg,#059669 0%,#10b981 100%);box-shadow:0 2px 4px #05966933}.btn-accent:hover{background:linear-gradient(135deg,#047857 0%,#059669 100%);transform:translateY(-1px);box-shadow:0 4px 8px #0596694d}.btn-sm{border-radius:8px;min-height:32px;padding:6px 12px;font-size:12px}.btn-block{justify-content:center;width:100%;padding:14px;font-size:16px}.dashboard-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--gray-150);border-right:1px solid var(--gray-200);z-index:100;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.mobile-topbar{height:var(--header-height);background:var(--white);border-bottom:1px solid var(--gray-200);z-index:99;box-shadow:var(--shadow);align-items:center;gap:12px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0}.mobile-topbar .hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:8px;display:flex}.mobile-topbar .hamburger span{background:var(--gray-700);border-radius:2px;width:24px;height:2px;display:block}.mobile-overlay{z-index:90;background:#0006;display:none;position:fixed;inset:0}.sidebar-header{border-bottom:1px solid var(--gray-200);background:var(--white);padding:24px 20px}.sidebar-header h2{color:var(--primary);margin:0;font-size:20px}.sidebar-header span{color:var(--gray-500);font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-sm);color:var(--gray-600);white-space:nowrap;border-left:3px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{background:var(--gray-200);color:var(--gray-900);transform:translate(2px)}.nav-item.active{background:var(--primary-light);color:var(--primary);border-left-color:var(--primary);font-weight:600}.nav-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{border-top:1px solid var(--gray-200);background:var(--white);padding:16px}.main-content{margin-left:var(--sidebar-width);max-width:calc(100% - var(--sidebar-width));flex:1;min-width:0;padding:32px;transition:margin-left .3s}@media (width<=1024px){.mobile-topbar{display:flex}.sidebar{z-index:101;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-overlay.open{display:block}.main-content{max-width:100%;padding:24px;padding-top:calc(var(--header-height) + 24px);margin-left:0}}@media (width<=640px){.main-content{padding:16px;padding-top:calc(var(--header-height) + 16px)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{color:var(--gray-900);margin:0;font-size:24px;font-weight:700}.header-count{background:var(--gray-100);min-width:28px;height:28px;color:var(--gray-700);vertical-align:middle;border-radius:20px;justify-content:center;align-items:center;margin-left:8px;padding:0 8px;font-size:13px;font-weight:700;line-height:1;display:inline-flex}@media (width<=640px){.page-header{flex-direction:column;align-items:flex-start}.page-header h1{font-size:22px}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--primary);border-radius:3px 3px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.stat-card .label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;font-size:12px;font-weight:600}.stat-card .value{color:var(--gray-900);font-size:32px;font-weight:700;line-height:1.2}.stat-card.warning .value{color:var(--warning)}.stat-card.warning:before{background:var(--warning)}.stat-card.danger .value{color:var(--danger)}.stat-card.danger:before{background:var(--danger)}.stat-card.success .value{color:var(--success)}.stat-card.success:before{background:var(--success)}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:16px}.stat-card .value{font-size:24px}}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200);transition:all .2s;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-header{border-bottom:1px solid var(--gray-200);background:var(--gray-50);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-header h2{color:var(--gray-900);margin:0;font-size:16px;font-weight:600}.card-body{padding:24px}@media (width<=640px){.card-body,.card-header{padding:16px}}.data-table-wrap{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);overflow-x:auto}.data-table-wrap::-webkit-scrollbar{height:8px}.data-table-wrap::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}.data-table-wrap::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}.data-table-wrap::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.data-table{border-collapse:collapse;background:var(--white);width:100%}.data-table thead{background:var(--gray-150)}.data-table th{text-align:left;color:var(--gray-600);text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid var(--gray-200);white-space:nowrap;padding:14px 16px;font-size:11px;font-weight:700}.data-table td{color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:14px 16px;font-size:14px}.data-table tbody tr{transition:background .15s}.data-table tbody tr:nth-child(2n){background:#fafbfc}.data-table tbody tr:hover{background:#f1f5f9}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:last-child td:first-child{border-bottom-left-radius:var(--radius-sm)}.data-table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-sm)}@media (width<=640px){.data-table thead{display:none}.data-table tbody,.data-table tr{display:block}.data-table tbody,.data-table tr,.data-table td{box-sizing:border-box;width:100%}.data-table tbody tr{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:20px;background:var(--white)!important}.data-table tbody tr:nth-child(2n),.data-table tbody tr:hover{background:var(--white)!important}.data-table tbody tr:last-child{margin-bottom:0}.data-table td{border:none;justify-content:flex-start;align-items:baseline;gap:0;padding:8px 0;font-size:16px;display:flex}.data-table td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.8px;color:var(--gray-500);flex-shrink:0;margin-right:8px;font-size:13px;font-weight:700}.data-table td[data-label="Actions: "]:last-child:before{display:none}.data-table td:last-child:before{display:block}.data-table td:last-child{border-top:1px dashed var(--gray-200);justify-content:flex-end;margin-top:8px;padding-top:10px;display:flex}.data-table td[data-label=Select]{justify-content:space-between;align-items:center;display:flex}.data-table td[data-label=Select]:before{content:"SELECT";text-transform:uppercase;letter-spacing:.8px;color:var(--gray-500);flex-shrink:0;margin-right:0;font-size:11px;font-weight:700}.data-table td[data-label=Select] input[type=checkbox]{width:18px;height:18px;margin:0}.data-table-wrap{box-shadow:none;background:0 0;border:none}div[style*=\#eff6ff]{flex-direction:column!important;align-items:stretch!important;gap:10px!important}}.form-group{margin-bottom:20px}.form-group label{color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;font-size:var(--font-size);background:var(--white);min-height:40px;padding:10px 14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr;gap:12px}}.invoice-items-table{width:100%;margin:16px 0}.invoice-items-table th,.invoice-items-table td{text-align:left;border-bottom:1px solid var(--gray-200);padding:12px}.invoice-items-table select,.invoice-items-table input{width:100%;padding:8px}.total-row{text-align:right;color:var(--gray-900);padding:16px;font-size:18px;font-weight:600}@media (width<=640px){.total-row{padding:12px;font-size:16px}}.search-box{background:var(--white);border:1px solid var(--gray-200);border-radius:10px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;display:flex;position:relative;box-shadow:0 1px 3px #0000000a}.search-box button{min-height:46px;padding:10px 18px;font-size:14px;font-weight:600}.search-box select{appearance:none;background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 72px center;cursor:pointer;border-radius:8px;min-height:46px;padding:10px 96px 10px 14px;font-size:15px}.search-box input{background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat 12px center;border-radius:8px;flex:1;min-width:0;min-height:46px;padding:10px 14px 10px 40px;font-size:15px}@media (width<=640px){.search-box{flex-direction:column;gap:10px}.search-box>div{width:100%!important;max-width:100%!important}.search-box input,.search-box select,.search-box button{width:100%;min-height:44px}.search-box input{padding:12px 8px 12px 36px;font-size:13px}.search-box select{background-position:right 14px center;padding:10px 36px 10px 12px;font-size:14px}.search-box input::placeholder{font-size:13px}.search-box button{justify-content:center;padding:10px 16px;font-size:14px}.search-box label{font-size:12px}.search-box input[type=search]{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}}.alert{border-radius:var(--radius-sm);border:1px solid #0000;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.alert-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.alert-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.alert-warning{color:#92400e;background:#fffbeb;border-color:#fcd34d}.alert-info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.empty-state{text-align:center;color:var(--gray-500);padding:48px 24px;font-weight:500}.two-panel{grid-template-columns:1fr 360px;align-items:start;gap:24px;display:grid}@media (width<=1024px){.two-panel{grid-template-columns:1fr}}.badge{white-space:nowrap;letter-spacing:.3px;border-radius:9999px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-block}.badge-draft{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}.badge-sent{color:#1e40af;background:#dbeafe;border:1px solid #93c5fd}.badge-paid{color:#166534;background:#d1fae5;border:1px solid #86efac}.badge-due{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.badge-cancelled{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}@media (pointer:coarse){.nav-item,.data-table td{padding:14px 16px}.btn{min-height:44px}.btn-sm{min-height:38px}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.main-content>*{animation:.3s ease-out fade-in}@media (width<=640px){.data-table td:last-child .btn-sm{padding:6px 8px;font-size:12px}}.sidebar-nav{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.status-dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.status-dot.active{background:var(--success)}.status-dot.inactive{background:var(--gray-400)}.status-dot.pending{background:var(--warning)}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{vertical-align:middle;animation:1s linear infinite spinner-rotate;display:inline-block}.loading-container{color:var(--gray-500);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:64px 24px;display:flex}.loading-container p{font-size:14px;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.btn-primary:active{transform:scale(.97);box-shadow:0 2px 8px #2563eb59}.btn-success:active,.btn-danger:active,.btn-secondary:active{transform:scale(.97)}.nav-item{position:relative;overflow:hidden}.nav-item:before{content:"";z-index:0;background:#2563eb14;border-radius:50%;width:0;height:0;transition:width .4s,height .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.nav-item:hover:before{width:200%;height:200%}.nav-item>*{z-index:1;position:relative}.nav-item:hover svg{transform:scale(1.1)}.nav-item.active svg{color:var(--primary)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:.35s cubic-bezier(.22,1,.36,1) forwards fadeSlideUp}@keyframes cardEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.card-animate{animation:.4s cubic-bezier(.22,1,.36,1) forwards cardEnter}.card-animate:first-child{opacity:0;animation-delay:50ms}.card-animate:nth-child(2){opacity:0;animation-delay:.1s}.card-animate:nth-child(3){opacity:0;animation-delay:.15s}.card-animate:nth-child(4){opacity:0;animation-delay:.2s}.page-header{border-bottom:1px solid var(--gray-200);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:28px;padding-bottom:16px;display:flex}.page-header h1{color:var(--gray-900);letter-spacing:-.4px;margin:0;font-size:28px;font-weight:800}.page-header h1:after{content:"";background:var(--primary);border-radius:2px;width:48px;height:4px;margin-top:8px;display:block}.page-header .subtitle{color:var(--gray-500);margin:4px 0 0;font-size:13px;font-weight:400}.page-header .header-icon{border-radius:var(--radius-sm);background:var(--primary-light);width:40px;height:40px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.page-header .header-left{align-items:center;gap:16px;display:flex}.breadcrumb{color:var(--gray-500);align-items:center;gap:8px;margin-bottom:12px;font-size:12px;display:flex}.breadcrumb a{color:var(--primary);font-weight:500;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .separator{color:var(--gray-400);font-size:10px}.divider{background:var(--gray-200);height:1px;margin:16px 0}.header-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}@media (width<=640px){.header-actions{justify-content:flex-start;width:100%}.header-actions .btn{flex:1;justify-content:center}}.empty-state-enhanced{text-align:center;color:var(--gray-500);padding:64px 24px}.empty-state-enhanced .empty-icon{width:80px;height:80px;color:var(--primary);background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex}.empty-state-enhanced h3{color:var(--gray-800);margin-bottom:8px;font-size:18px;font-weight:600}.empty-state-enhanced p{color:var(--gray-500);max-width:400px;margin:0 auto 24px;font-size:14px}@media (width<=1024px){.sidebar{box-shadow:4px 0 24px #00000026}.sidebar.open{transform:translate(0)}.mobile-overlay{opacity:0;transition:opacity .3s}.mobile-overlay.open{opacity:1;display:block}}@media (width<=640px){.data-table thead{display:none}.data-table tbody tr{border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--white);box-shadow:var(--shadow-sm);margin-bottom:12px;padding:16px;display:block}.data-table tbody tr:nth-child(2n),.data-table tbody tr:hover{background:var(--white)}.data-table td{border-bottom:1px solid var(--gray-100);justify-content:flex-start;align-items:baseline;gap:0;padding:8px 0;font-size:13px;display:flex}.data-table td:last-child{border-bottom:none;border-top:2px solid var(--gray-100);justify-content:flex-end;margin-top:4px;padding-top:12px;display:flex}.data-table td:before{content:attr(data-label);color:var(--gray-600);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;margin-right:1px;font-size:11px;font-weight:600}.data-table td[data-label="Actions: "]:last-child:before{display:none}.data-table td:last-child:before{display:block}.data-table td .btn-sm{padding:6px 10px;font-size:11px}}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #2563eb1a}@media (width<=640px){.card-header{flex-direction:column;align-items:flex-start;gap:8px;padding:16px}.card-header h2{font-size:15px}.card-body{padding:16px}.search-box{flex-direction:column;gap:8px}.search-box input{max-width:100%}.search-box button{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:16px}.stat-card .value{font-size:24px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-header .header-left,.page-header .header-actions,.page-header>div:last-child{width:100%}.page-header .header-actions .btn,.page-header>div:last-child .btn{flex:1;justify-content:center}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.alert{animation:.25s ease-out slideInDown}html{scroll-behavior:smooth}.toast-in{animation:.35s cubic-bezier(.22,1,.36,1) forwards toastSlideIn}@keyframes toastSlideIn{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}.suggestions-dropdown{background:var(--white);border:1px solid var(--gray-200);z-index:100;border-radius:8px;max-height:220px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.suggestion-item{cursor:pointer;border-bottom:1px solid var(--gray-100);padding:10px 14px;font-size:14px}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--gray-50)}.status-badge{text-transform:capitalize;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.status-badge.draft{color:#6b7280;background:#f3f4f6}.status-badge.active{color:#1d4ed8;background:#dbeafe}.status-badge.completed{color:#15803d;background:#dcfce7}.status-badge.cancelled{color:#b91c1c;background:#fee2e2}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;justify-content:center;align-items:center;animation:.2s ease-out backdropFade;display:flex;position:fixed;inset:0}@keyframes backdropFade{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-xl);width:90%;max-width:520px;padding:28px 32px;animation:.3s cubic-bezier(.22,1,.36,1) forwards modalScaleIn}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.row-delete{pointer-events:none;animation:.35s cubic-bezier(.4,0,.2,1) forwards rowSlideOut}@keyframes rowSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-60px)}}@media print{.sidebar,.mobile-topbar,.page-header .header-actions,nav.breadcrumb,.btn{display:none!important}.main-content{max-width:100%;margin-left:0;padding:0}}.invoice-status-banner{border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px 28px;display:flex}.invoice-status-banner.paid{background:#f0fdf4;border:2px solid #86efac}.invoice-status-banner.due{background:#fef2f2;border:2px solid #fecaca}.invoice-status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;justify-content:center;align-items:center;padding:8px 24px;font-size:13px;font-weight:700;display:inline-flex}.invoice-detail-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);overflow:hidden}.invoice-detail-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:28px 32px 0;display:flex}.invoice-company-name{color:var(--primary);margin-bottom:2px;font-size:24px;font-weight:700}.invoice-from-to{grid-template-columns:1fr 1fr;gap:24px;padding:0 32px 28px;display:grid}.invoice-info-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;padding:18px 20px}.invoice-info-label{text-transform:uppercase;letter-spacing:.6px;color:var(--gray-400);margin-bottom:8px;font-size:11px;font-weight:600}.invoice-info-value{color:var(--gray-800);font-size:15px;font-weight:600;line-height:1.4}.invoice-info-sub{color:var(--gray-600);margin-top:4px;font-size:13px}.invoice-table-wrap{border:1px solid var(--gray-200);border-radius:8px;margin:0 32px 28px;overflow:hidden}.invoice-table{border-collapse:collapse;width:100%}.invoice-table thead th{background:var(--gray-50);text-transform:uppercase;letter-spacing:.4px;color:var(--gray-500);border-bottom:1px solid var(--gray-200);text-align:left;padding:12px 16px;font-size:12px;font-weight:600}.invoice-table thead th:last-child,.invoice-table tbody td:last-child{text-align:right}.invoice-table tbody td{border-bottom:1px solid var(--gray-150);vertical-align:middle;padding:14px 16px;font-size:14px}.invoice-table tbody tr:last-child td{border-bottom:none}.invoice-totals-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;max-width:360px;margin-left:auto;padding:20px 24px}.invoice-totals-row{color:var(--gray-600);border-bottom:1px solid var(--gray-200);justify-content:space-between;padding:8px 0;font-size:14px;display:flex}.invoice-totals-row:last-child{border-bottom:none}.invoice-totals-row.grand{color:var(--gray-900);padding:14px 0;font-size:18px;font-weight:700}.invoice-totals-row.net{color:var(--gray-900);border-bottom:2px solid var(--gray-300);padding:10px 0;font-size:16px;font-weight:600}.invoice-terms-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;margin:28px 32px;padding:20px 24px}.invoice-terms-box h4{text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);margin-bottom:12px;font-size:12px;font-weight:600}.invoice-terms-box pre{color:var(--gray-600);white-space:pre-wrap;margin:0;font-family:inherit;font-size:13px;line-height:1.7}@media (width<=640px){.invoice-from-to{grid-template-columns:1fr}.invoice-detail-header{flex-direction:column;gap:12px}.invoice-status-banner{text-align:center;flex-direction:column;gap:12px}.invoice-table-wrap{margin:0 16px 20px}.invoice-table thead th,.invoice-table tbody td{padding:10px 12px;font-size:13px}.invoice-totals-box{max-width:none}.invoice-from-to{padding:0 16px 20px}.invoice-terms-box{margin:20px 16px}}@media print{.invoice-detail-card{box-shadow:none;border:none}.invoice-status-banner{border-width:1px!important}.invoice-table-wrap,.invoice-info-box{border:1px solid #ddd}}.skeleton{background:linear-gradient(90deg, var(--gray-150) 25%, var(--gray-200) 50%, var(--gray-150) 75%);background-size:200% 100%;border-radius:4px;animation:1.4s ease-in-out infinite skeleton-shimmer}.skeleton-card{border-radius:var(--radius);height:120px}.skeleton-card-inner{flex-direction:column;gap:12px;padding:24px;display:flex}.skeleton-card-top{justify-content:space-between;align-items:flex-start;display:flex}.skeleton-card-bar{border-radius:4px;height:12px}.skeleton-card-bar.short{width:40%}.skeleton-card-bar.medium{width:60%}.skeleton-card-bar.wide{width:90%}.skeleton-card-avatar{border-radius:12px;width:48px;height:48px}.skeleton-card-value{border-radius:6px;width:80px;height:36px}.skeleton-table-header{border-bottom:1px solid var(--gray-200);gap:8px;padding:14px 16px;display:flex}.skeleton-table-header-cell{border-radius:4px;flex:1;height:16px}.skeleton-table-header-cell:first-child{flex:2}.skeleton-table-row{border-bottom:1px solid var(--gray-200);gap:8px;padding:14px 16px;display:flex}.skeleton-table-row-cell{border-radius:4px;flex:1;height:16px}.skeleton-table-row-cell:first-child{flex:2}.skeleton-text{border-radius:4px;height:14px}.skeleton-text.line{width:100%}.skeleton-text.short{width:40%}.skeleton-text.med{width:70%}.skeleton-page-header{border-radius:6px;width:200px;height:36px;margin-bottom:8px}.skeleton-page-sub{border-radius:4px;width:140px;height:16px;margin-bottom:24px}.btn-loading{pointer-events:none;opacity:.85;position:relative}.btn-loading .btn-spinner{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;margin-right:8px;animation:.8s linear infinite spin;display:inline-block}.btn-loading.btn-secondary .btn-spinner{border:2px solid #0f172a26;border-top-color:var(--gray-700)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.toast-enter{animation:.3s ease-out fadeSlideUp}.section-label{text-transform:uppercase;letter-spacing:.6px;color:var(--gray-500);margin-bottom:12px;font-size:11px;font-weight:600;display:block}.image-hover-preview{z-index:100;border:1px solid var(--gray-200);background:#fff;border-radius:8px;padding:4px;display:none;position:absolute;top:-40px;left:70px;box-shadow:0 8px 24px #0003}.image-hover-preview img{object-fit:contain;border-radius:6px;width:180px;height:180px;display:block}.data-table td:hover .image-hover-preview{display:block}@media (width<=640px){.data-table td:hover .image-hover-preview{display:none}}.form-row{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.form-row input[type=text],.form-row input[type=email],.form-row input[type=password],.form-row input[type=number],.form-row input[type=search],.form-row input[type=tel]{min-height:42px;padding:10px 12px}@media (width<=640px){.form-row{grid-template-columns:1fr}.form-row input[type=text]{min-height:44px;padding:11px 12px;font-size:16px}}.module-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200);overflow:hidden}@media (width<=640px){.module-card .form-group[style*="gridColumn: '1 / -1'"]>div{justify-content:center!important}.card-body .form-row{grid-template-columns:1fr!important;gap:12px!important}.card-body .form-actions{flex-direction:column;gap:10px;display:flex}.card-body .form-actions .btn{justify-content:center;width:100%;min-height:44px;margin:0!important}.card-body [style*="position: absolute; top: 100%;"]{max-width:100vw;left:0!important;right:0!important}.module-card .card-body>div[style*="overflowX: auto"]{overflow-x:visible!important}.module-card table.data-table{min-width:auto!important}.page-header .btn{min-height:40px;padding:8px 16px;font-size:13px}.data-table td[data-label="Image: "]:before{display:none}.data-table td[data-label="Image: "]{padding:8px 0;justify-content:center!important}.data-table td[data-label="Product Name: "]{flex-direction:column;align-items:flex-start}.data-table td[data-label="Product Name: "]:before{margin-bottom:4px}}.tracking-table-desktop{display:table}.tracking-cards{display:none}@media (width<=640px){.tracking-table-desktop{display:none!important}.tracking-cards{display:block}.search-box{flex-wrap:wrap;gap:8px}.search-box input{width:100%;margin-bottom:0}.search-box select{flex:1;min-width:120px!important}.tracking-card{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:28px;padding:18px}.tracking-card:last-child{margin-bottom:0}.tc-shipment{border-bottom:1px dashed var(--gray-200);margin-bottom:10px;padding-bottom:10px}.tc-serial{color:var(--primary);font-size:18px;font-weight:700;line-height:1.3}.tc-meta{color:var(--gray-500);margin-top:2px;font-size:13px}.tc-product{color:var(--gray-900);word-break:break-word;margin-bottom:12px;font-size:16px;font-weight:600;line-height:1.4}.tc-unit{color:var(--primary);background:#f0f5ff;border-radius:6px;margin-bottom:12px;padding:4px 10px;font-size:14px;font-weight:600;display:inline-block}.tc-fields{margin-bottom:14px}.tc-field{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:baseline;gap:12px;padding:6px 0;display:flex}.tc-field:last-child{border-bottom:none}.tc-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:600}.tc-value{color:var(--gray-800);text-align:right;word-break:break-word;font-size:15px;font-weight:500}.tc-status-row{border-top:1px dashed var(--gray-200);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;padding-top:12px;display:flex}.tc-status-badge{white-space:nowrap;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-block}.tc-status-select{border-radius:6px;flex:1;min-width:145px;max-width:100%;padding:8px 10px;font-size:14px}.tc-actions{flex-wrap:nowrap!important;justify-content:space-between!important;gap:0!important;display:flex!important}.tc-action-left{text-align:left}.tc-action-right{text-align:right}.tc-actions .btn-sm{border-radius:10px;min-width:90px;min-height:42px;margin:0;padding:10px 20px;font-size:14px}.tc-actions .btn-sm:first-child{margin-right:0}.data-table td[data-label=Actions]:last-child:before{display:none}}
