:root{--color-primary:#c9252d;--color-primary-dark:#7f1117;--color-bg:#f4f5f7;--color-panel:#fff;--color-dark:#080808;--color-sidebar:#151a22;--color-muted:#667085;--color-border:#e4e7ec;--sidebar-width:220px;--content-max:1280px;--list-max:1200px;--shell-max:1360px;--topbar-height:64px;--shadow-soft:0 10px 30px #0808080f;--shadow-panel:0 16px 40px #0808080d;--radius-card:16px;--radius-button:12px;--red:var(--color-primary);--red-dark:var(--color-primary-dark);--black:var(--color-dark);--white:#fff;--gray-100:var(--color-bg);--gray-300:var(--color-border);--gray-600:var(--color-muted);color:var(--color-dark);background:var(--color-bg);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:var(--color-bg);min-width:320px;margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{background:var(--color-bg);min-height:100vh}.app-sidebar{z-index:40;width:var(--sidebar-width);background:var(--color-sidebar);color:#e5e7eb;border-right:1px solid #ffffff0f;flex-direction:column;height:100vh;display:none;position:fixed;inset:0 auto 0 0;overflow:hidden}.sidebar-brand{border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.55rem;padding:.65rem .75rem .6rem;display:flex}.sidebar-brand-mark{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));width:32px;height:32px;color:var(--white);border-radius:9px;flex-shrink:0;place-items:center;font-size:.78rem;font-weight:800;display:grid}.sidebar-brand-title{color:var(--white);letter-spacing:.01em;margin:0;font-size:.84rem;font-weight:800;line-height:1.15}.sidebar-brand-subtitle{color:#9ca3af;margin:.08rem 0 0;font-size:.62rem;line-height:1.25}.sidebar-nav{scrollbar-width:none;-ms-overflow-style:none;flex:1;padding:.45rem .55rem .65rem;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:0;height:0;display:none}.sidebar-group+.sidebar-group{margin-top:.5rem}.sidebar-group-title{letter-spacing:.08em;text-transform:uppercase;color:#8b95a5;margin:0 0 .22rem;padding:0 .45rem;font-size:.62rem;font-weight:700}.sidebar-menu{flex-direction:column;gap:.12rem;margin:0;padding:0;list-style:none;display:flex}.sidebar-link{color:#d4d4d4;border:1px solid #0000;border-radius:12px;align-items:center;gap:.55rem;height:40px;padding:0 .55rem;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:flex}.sidebar-link:hover{color:var(--white);background:#ffffff0a}.sidebar-link.active{color:var(--white);background:#c9252d24;border:1px solid #c9252d59}.sidebar-link.active .sidebar-link-icon{color:#fecdd3;background:#c9252d29}.sidebar-link-icon{background:#ffffff0d;border-radius:9px;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:.6rem;font-weight:800;display:grid}.sidebar-footer{border-top:1px solid #ffffff0f;flex-shrink:0;padding:.55rem .65rem .65rem}.sidebar-user{align-items:center;gap:.45rem;margin-bottom:.45rem;display:flex}.sidebar-user-avatar{color:#ffd7da;background:#c9252d2e;border-radius:999px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:.68rem;font-weight:800;display:grid}.sidebar-user-copy strong{color:var(--white);font-size:.72rem;line-height:1.15;display:block}.sidebar-user-copy span{color:#9ca3af;text-transform:lowercase;font-size:.62rem;display:block}.btn-sidebar-logout{color:#d4d4d4;background:#ffffff0a;border:1px solid #ffffff14;width:100%;height:40px;min-height:40px;padding:0 .65rem;font-size:.75rem;font-weight:600}.btn-sidebar-logout:hover{color:var(--white);background:#c9252d24;border-color:#c9252d59}.app-content{background:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.app-topbar{z-index:20;height:var(--topbar-height);max-height:var(--topbar-height);background:var(--color-panel);border-bottom:1px solid #eaecf0;flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 1px #0f172a0f}.topbar-left,.topbar-right{align-items:center;gap:.75rem;display:flex}.topbar-menu-btn{border:1px solid var(--color-border);background:var(--color-panel);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;gap:4px;width:40px;height:40px;padding:0;display:inline-flex}.topbar-menu-btn span{background:var(--color-dark);border-radius:999px;width:16px;height:2px;margin:0 auto;display:block}.topbar-context{min-width:0}.topbar-kicker{letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);margin:0;font-size:11px;font-weight:700;line-height:1.2}.topbar-title{color:var(--color-dark);margin:.06rem 0 0;font-size:15px;font-weight:700;line-height:1.2}.topbar-meta{flex-direction:column;align-items:flex-end;gap:.05rem;display:none}.topbar-role{color:var(--color-dark);text-transform:lowercase;font-size:.72rem;font-weight:600}.topbar-date{color:var(--color-muted);white-space:nowrap;font-size:.65rem}.topbar-logout{height:36px;min-height:36px;padding:0 14px;font-size:.75rem;font-weight:600;display:none}.app-drawer,.sidebar-backdrop{display:none}.app-drawer{z-index:50;background:var(--color-sidebar);width:min(86vw,300px);height:100vh;color:var(--white);scrollbar-width:none;-ms-overflow-style:none;padding-bottom:1rem;transition:transform .22s;position:fixed;inset:0 auto 0 0;overflow-y:auto;transform:translate(-100%)}.app-drawer::-webkit-scrollbar{display:none}.app-drawer.open{transform:translate(0)}.sidebar-backdrop{z-index:45;cursor:pointer;background:#08080873;border:none;position:fixed;inset:0}.drawer-logout{margin:.75rem .85rem 0}.mobile-bottom-nav{z-index:30;background:var(--color-sidebar);padding-bottom:env(safe-area-inset-bottom,0);border-top:1px solid #ffffff14;grid-template-columns:repeat(5,1fr);display:grid;position:fixed;bottom:0;left:0;right:0}.mobile-nav-link{color:#bdbdbd;cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;min-height:58px;padding:.45rem .25rem;font-size:.68rem;font-weight:700;display:flex}.mobile-nav-link.active{color:var(--white);background:#c9252d38}.mobile-nav-icon{font-size:.72rem;font-weight:800}.app-main{width:100%;max-width:var(--shell-max);padding:.75rem 1rem;padding-bottom:calc(4.75rem + env(safe-area-inset-bottom,0));flex:1;margin:0 auto}.page{width:100%;max-width:var(--content-max);flex-direction:column;gap:.75rem;margin:0 auto;display:flex}.page:not(.dashboard-page){max-width:var(--list-max);padding-top:28px}.page-header{width:100%;max-width:var(--list-max);justify-content:space-between;align-items:center;gap:.75rem;margin:0 auto;display:flex}.page-header h2{max-width:100%;font-size:clamp(1.05rem,1.8vw,1.35rem)}.page-header .btn-primary{white-space:nowrap;border-radius:12px;height:44px;min-height:44px;padding:0 1rem;font-size:.84rem}.page-header h2,.hero-card h2,.login-brand h1{margin:0}.bottom-nav,.app-header{display:none}.nav-link{color:#ccc;text-align:center;padding:.85rem .5rem;font-size:.85rem;font-weight:600}.nav-link.active{color:var(--white);background:#c9252d40}.muted{color:var(--color-muted);margin:.25rem 0 0}.card{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);padding:1rem}.hero-card{background:linear-gradient(135deg, var(--black), #1f1f1f);color:var(--white);border-radius:16px;padding:1.25rem}.hero-kicker{color:var(--red);text-transform:uppercase;margin:0;font-size:.85rem;font-weight:700}.menu-grid{gap:1rem;display:grid}.menu-card{background:var(--white);border:1px solid var(--gray-300);border-left:4px solid var(--red);border-radius:14px;align-items:center;gap:1rem;padding:1rem;display:flex}.menu-icon{background:var(--red);width:44px;height:44px;color:var(--white);border-radius:12px;place-items:center;font-weight:700;display:grid}.form-stack{flex-direction:column;gap:.85rem;display:flex}.form-stack label{flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:600;display:flex}.form-stack input,.form-stack select,.form-stack textarea{border:1px solid var(--color-border);border-radius:var(--radius-button);background:var(--color-panel);min-height:44px;padding:.75rem .85rem}.payment-form-grid{gap:.85rem;display:grid}.payment-form-grid .payment-form-field{flex-direction:column;gap:.35rem;display:flex}.payment-form-grid .payment-form-full{grid-column:1/-1}@media (width>=768px){.payment-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.btn{border-radius:var(--radius-button);cursor:pointer;border:none;min-height:44px;padding:.75rem 1rem;font-weight:700}.btn-sm,.compact-actions .btn,.compact-card-actions .btn{border-radius:12px;height:36px;min-height:36px;padding:0 14px;font-size:.78rem;font-weight:600}.btn-primary{background:var(--color-primary);color:var(--white)}.btn-primary:hover{background:var(--color-primary-dark)}.btn-outline{color:var(--color-dark);border:1px solid var(--color-border);background:0 0}.btn-danger{background:var(--color-dark);color:var(--white);border:1px solid var(--color-primary-dark)}.btn-danger:hover{background:var(--color-primary-dark)}.button-row{flex-wrap:wrap;gap:.5rem;display:flex}.list-stack{flex-direction:column;gap:.85rem;display:flex}.list-toolbar{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);max-width:var(--list-max);flex-direction:column;gap:.4rem;width:100%;margin:0 auto;padding:.45rem .55rem;display:flex}.list-toolbar-input{border:1px solid var(--color-border);background:var(--color-panel);border-radius:10px;width:100%;height:36px;min-height:36px;padding:.35rem .55rem;font-size:.82rem}.list-toolbar-filters{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.list-toolbar-field{color:var(--gray-600);text-transform:uppercase;letter-spacing:.03em;flex-direction:column;gap:.2rem;font-size:.72rem;font-weight:700;display:flex}.list-toolbar-field select{border:1px solid var(--color-border);height:36px;min-height:36px;color:var(--color-dark);background:var(--color-panel);text-transform:none;letter-spacing:normal;border-radius:8px;padding:.35rem .5rem;font-size:.82rem;font-weight:600}.list-toolbar-meta{color:var(--gray-600);margin:0;font-size:.75rem}.list-toolbar-secondary{margin-top:-.25rem;padding-top:0}.list-toolbar-secondary .list-toolbar-filters{width:100%}.compact-table-wrap{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);max-width:var(--list-max);width:100%;margin:0 auto;display:none;overflow:hidden}.compact-table{border-collapse:collapse;width:100%;font-size:.82rem}.compact-table th,.compact-table td{border-bottom:1px solid var(--color-border);text-align:left;vertical-align:middle;max-height:64px;padding:.35rem .55rem}.compact-table th{text-transform:uppercase;letter-spacing:.04em;height:38px;color:var(--color-muted);background:#f2f4f7;font-size:11px;font-weight:700}.compact-table tbody tr:last-child td{border-bottom:none}.compact-table tbody tr:hover{background:#fafafa}.compact-col-actions{white-space:nowrap;width:1%}.compact-col-doc{min-width:7rem;color:var(--red);font-weight:700}.compact-col-party{max-width:11rem}.compact-col-date{white-space:nowrap;color:var(--gray-600);font-size:.8rem}.compact-col-amount{white-space:nowrap;text-align:right;font-weight:700}.compact-col-status{white-space:nowrap}.compact-actions,.compact-card-actions{flex-wrap:wrap;gap:.35rem;display:flex}.compact-card-list{max-width:var(--list-max);flex-direction:column;gap:.45rem;width:100%;margin:0 auto;display:flex}.compact-card{background:var(--white);border:1px solid var(--gray-300);border-radius:10px;flex-direction:column;gap:.35rem;padding:.55rem .65rem;display:flex}.compact-card-head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.compact-card-title{color:var(--red);min-width:0;font-size:.88rem;font-weight:800;line-height:1.25}.compact-card-badge{flex-shrink:0}.compact-card-subtitle{color:var(--gray-600);margin:0;font-size:.78rem;line-height:1.35}.compact-card-meta{color:var(--gray-600);flex-wrap:wrap;align-items:center;gap:.35rem .65rem;font-size:.75rem;display:flex}.compact-card-amount{color:var(--black);margin-left:auto;font-size:.82rem}.compact-card-actions .btn{padding:.35rem .55rem;font-size:.78rem}.compact-card-actions .btn-block-mobile{min-height:44px}.compact-empty{padding:1.25rem .75rem;font-size:.88rem}.cell-ellipsis{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.cell-clamp-2{-webkit-line-clamp:2;color:var(--gray-600);-webkit-box-orient:vertical;font-size:.78rem;line-height:1.35;display:-webkit-box;overflow:hidden}.doc-number{color:var(--red);font-size:.88rem;font-weight:800}.status-badge-compact{color:var(--red);text-transform:uppercase;letter-spacing:.02em;background:#c628281a;border-radius:999px;padding:.15rem .45rem;font-size:.68rem;font-weight:700;display:inline-block}.list-card{flex-direction:column;gap:.85rem;display:flex}.list-card h3{margin:0}.empty-state{text-align:center;color:var(--gray-600);background:var(--white);border:1px dashed var(--gray-300);border-radius:14px;padding:2rem 1rem}.error-text{color:var(--red);margin:0;font-weight:600}.status-badge{color:var(--red);text-transform:uppercase;background:#c628281f;border-radius:999px;margin-top:.35rem;padding:.25rem .6rem;font-size:.75rem;font-weight:700;display:inline-block}.login-page{background:linear-gradient(180deg, var(--black) 0%, #1a1a1a 100%);place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{background:var(--white);border-radius:18px;width:100%;max-width:420px;padding:1.5rem}.login-brand{text-align:center;margin-bottom:1.25rem}.login-brand h1{color:var(--red)}.items-section{flex-direction:column;gap:.75rem;display:flex}.items-header{justify-content:space-between;align-items:center;display:flex}.item-row{grid-template-columns:1fr;gap:.5rem;display:grid}.detail-grid{gap:1rem;display:grid}.detail-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.75rem;display:block}.grand-total{color:var(--red);font-size:1.25rem;font-weight:800}.quotation-number{color:var(--red);letter-spacing:.02em;margin:0;font-weight:800}.table-wrap{max-height:min(70vh,720px);overflow:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.9rem}.data-table th,.data-table td{border-bottom:1px solid var(--color-border);text-align:left;vertical-align:middle;padding:.45rem .55rem}.data-table th{z-index:1;height:38px;color:var(--color-muted);text-transform:uppercase;box-shadow:inset 0 -1px 0 var(--color-border);background:#f2f4f7;font-size:11px;position:sticky;top:0}.data-table tbody tr{max-height:64px}.data-table tbody td{font-size:.82rem;line-height:1.35}@media (width>=640px){.menu-grid{grid-template-columns:repeat(2,1fr)}.list-toolbar-filters{grid-template-columns:repeat(3,minmax(0,1fr))}.list-card{flex-direction:row;justify-content:space-between;align-items:center}.item-row{grid-template-columns:2fr .7fr .7fr 1fr auto;align-items:center}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=768px){.app-drawer,.sidebar-backdrop,.mobile-bottom-nav,.topbar-menu-btn{display:none}.app-sidebar{display:flex}.app-content{margin-left:var(--sidebar-width)}.app-main{padding:.65rem 20px 20px}.topbar-meta,.topbar-logout{display:flex}.topbar-title{font-size:.9rem}.compact-table-wrap{display:block}.compact-card-list{display:none}.list-toolbar{flex-flow:wrap;align-items:flex-end;gap:.5rem .75rem}.list-toolbar-search{flex:220px;min-width:180px}.list-toolbar-filters{flex:2 320px}.list-toolbar-meta{flex:none;align-self:center;margin-left:auto}}.dashboard-page{max-width:var(--content-max);gap:16px;padding-top:0;padding-bottom:.25rem}.dash-hero,.dash-hero-premium{color:var(--white);border-radius:var(--radius-card);max-height:118px;box-shadow:var(--shadow-soft);background:radial-gradient(circle at 100% 0,#c9252d1f,#0000 38%),linear-gradient(135deg,#1e2430 0%,#252b38 52%,#2a2230 100%);border:1px solid #ffffff12;gap:.35rem;padding:14px 18px;display:grid;overflow:hidden}.dash-hero-executive{grid-template-columns:1fr auto;align-items:center}.dash-kpi-primary-grid,.dash-kpi-secondary-grid{gap:16px;display:grid}.dash-kpi-primary,.dash-kpi-secondary{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);min-height:0;max-height:96px;box-shadow:var(--shadow-soft);border-left:3px solid #0000;flex-direction:column;justify-content:center;padding:16px 18px;display:flex;overflow:hidden}.dash-kpi-accent-revenue{border-left-color:#86efac}.dash-kpi-accent-profit{border-left-color:#93c5fd}.dash-kpi-accent-piutang{border-left-color:#fdba74}.dash-kpi-accent-work-order{border-left-color:#fca5a5}.dash-kpi-primary-label,.dash-kpi-secondary-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted);margin:0;font-size:12px;font-weight:700}.dash-kpi-primary-value{color:var(--color-dark);margin:.2rem 0 0;font-size:26px;font-weight:800;line-height:1.05}.dash-kpi-primary-hint,.dash-kpi-secondary-hint{color:var(--color-muted);white-space:nowrap;text-overflow:ellipsis;margin:.15rem 0 0;font-size:.68rem;line-height:1.25;overflow:hidden}.dash-kpi-secondary-value{color:var(--color-dark);margin:.2rem 0 0;font-size:22px;font-weight:800;line-height:1.05}.dash-kpi-secondary-alert{border-color:#c9252d38}.dash-kpi-secondary-alert .dash-kpi-secondary-value{color:var(--color-primary)}.dash-section-block{flex-direction:column;gap:16px;display:flex}.dash-activity-panel{height:100%}.dash-hero-main h2{max-height:1.2em;margin:.08rem 0 0;font-size:22px;line-height:1.15}.dash-hero-main .hero-kicker{letter-spacing:.08em;font-size:10px}.dash-hero-subtitle{color:#b8bcc6;white-space:nowrap;text-overflow:ellipsis;margin:.1rem 0 0;font-size:.7rem;line-height:1.2;overflow:hidden}.dash-hero-summary{color:#b8b8b8;max-width:42rem;margin:.85rem 0 0;font-size:.9rem;line-height:1.55}.dash-hero-side{flex-direction:column;justify-content:center;align-items:flex-end;gap:.25rem;min-width:0;display:flex}.dash-hero-mini-kpis{flex-wrap:wrap;justify-content:flex-end;align-items:stretch;gap:.5rem;display:flex}.dash-hero-mini-kpi{background:#ffffff0f;border:1px solid #ffffff14;border-radius:10px;min-width:88px;padding:.35rem .55rem}.dash-hero-mini-kpi span{letter-spacing:.06em;text-transform:uppercase;color:#9ca3af;font-size:9px;font-weight:700;line-height:1.2;display:block}.dash-hero-mini-kpi strong{color:var(--white);white-space:nowrap;margin-top:.12rem;font-size:.78rem;font-weight:700;line-height:1.2;display:block}.dash-hero-updated{color:#9ca3af;margin:0;font-size:.65rem}.dash-hero-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.dash-hero-stat{background:#ffffff0f;border:1px solid #ffffff14;border-radius:16px;padding:.85rem .95rem}.dash-hero-stat span{text-transform:uppercase;letter-spacing:.05em;color:#bdbdbd;font-size:.72rem;display:block}.dash-hero-stat strong{margin-top:.35rem;font-size:.95rem;line-height:1.3;display:block}.dash-live-badge{color:#ffcaca;text-transform:uppercase;letter-spacing:.06em;background:#c9252d29;border-radius:999px;align-items:center;gap:.3rem;width:fit-content;padding:.22rem .55rem;font-size:.65rem;font-weight:700;display:inline-flex}.dash-live-badge:before{content:"";background:#ff5252;border-radius:50%;width:7px;height:7px;box-shadow:0 0 0 4px #ff52522e}.dash-quick-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;display:grid}.dash-quick-action{background:var(--white);border:1px solid #0000000f;border-radius:18px;align-items:center;gap:.75rem;padding:.95rem 1.05rem;font-size:.88rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 12px 30px #0000000d}.dash-quick-action span{width:38px;height:38px;color:var(--white);background:linear-gradient(#d32f2f,#b71c1c);border-radius:12px;flex-shrink:0;place-items:center;font-size:.72rem;font-weight:800;display:grid}.dash-quick-action:hover{transform:translateY(-2px);box-shadow:0 16px 34px #c628281f}.dash-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.dash-kpi-card{background:var(--white);border:1px solid #0000000f;border-radius:22px;padding:1.15rem 1.2rem;box-shadow:0 16px 36px #0000000d}.dash-kpi-card-accent{background:linear-gradient(#fff 0%,#fff7f7 100%);border-color:#c628282e}.dash-kpi-top{align-items:flex-start;gap:.85rem;display:flex}.dash-kpi-icon{width:44px;height:44px;color:var(--black);background:#f3f3f3;border-radius:14px;flex-shrink:0;place-items:center;font-size:.78rem;font-weight:800;display:grid}.dash-kpi-icon-accent{color:var(--red);background:#c628281f}.dash-kpi-copy{min-width:0}.dash-kpi-label{color:var(--black);margin:0;font-size:.92rem;font-weight:800}.dash-kpi-subtitle{color:var(--gray-600);margin:.15rem 0 0;font-size:.76rem}.dash-kpi-value{color:var(--black);margin:1rem 0 0;font-size:clamp(1.25rem,2vw,1.55rem);font-weight:800;line-height:1.15}.dash-kpi-card-accent .dash-kpi-value{color:var(--red)}.dash-kpi-meta{color:var(--gray-600);margin:.45rem 0 0;font-size:.76rem;line-height:1.45}.dash-grid-two,.dash-activity-grid,.dash-side-stack{gap:16px;display:grid}.dash-analytics-row{align-items:stretch}.dash-panel{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);padding:18px}.dash-panel-compact{padding:16px}.dash-panel-header{justify-content:space-between;align-items:flex-start;gap:.65rem;margin-bottom:.65rem;display:flex}.dash-panel-header-split{flex-wrap:wrap;align-items:stretch}.dash-panel-header h3,.dash-section-title h3{margin:0;font-size:.92rem;font-weight:700}.dash-panel-subtitle,.dash-section-title .dash-panel-subtitle{color:var(--color-muted);margin:.2rem 0 0;font-size:.72rem}.dash-chart-ytd{flex-wrap:wrap;gap:.85rem;display:flex}.dash-chart-ytd div{background:#fafafa;border:1px solid #0000000d;border-radius:14px;min-width:120px;padding:.75rem .85rem}.dash-chart-ytd span{text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);font-size:.72rem;display:block}.dash-chart-ytd strong{color:var(--black);margin-top:.3rem;font-size:.92rem;display:block}.dash-chart-wrap{width:100%;height:240px;max-height:240px}.dash-chart-tooltip{background:var(--black);color:var(--white);border-radius:12px;flex-direction:column;gap:.25rem;padding:.65rem .85rem;font-size:.82rem;display:flex;box-shadow:0 10px 24px #0000002e}.dash-funnel{flex-direction:column;gap:14px;display:flex}.dash-funnel-step{position:relative}.dash-funnel-label,.dash-status-meta{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.35rem;font-size:.82rem;display:flex}.dash-funnel-label span{color:var(--color-muted);font-weight:600}.dash-funnel-label strong{color:var(--color-dark);font-size:.88rem;font-weight:700}.dash-funnel-bar,.dash-status-track{background:#eef1f5;border-radius:999px;height:6px;overflow:hidden}.dash-funnel-fill,.dash-status-fill{border-radius:999px;height:100%;transition:width .2s}.dash-funnel-fill.step-1{background:#cbd5e1}.dash-funnel-fill.step-2{background:#94a3b8}.dash-funnel-fill.step-3{background:#64748b}.dash-funnel-fill.step-4{background:#c9252dbf}.dash-status-fill-red{background:var(--red)}.dash-status-fill-dark{background:var(--black)}.dash-status-list{flex-direction:column;gap:.85rem;display:flex}.dash-funnel-arrow{display:none}.dash-top-customers{flex-direction:column;gap:1rem;display:flex}.dash-top-customer-row{align-items:flex-start;gap:.85rem;display:flex}.dash-rank-badge{width:34px;height:34px;color:var(--black);background:#f3f3f3;border-radius:12px;flex-shrink:0;place-items:center;font-size:.82rem;font-weight:800;display:grid}.dash-rank-badge.rank-gold{color:#9a6b00;background:#fff3cd}.dash-rank-badge.rank-silver{color:#5f6b7a;background:#eef1f4}.dash-rank-badge.rank-bronze{color:#8b5a3c;background:#f7e8df}.dash-top-customer-body{flex:1;min-width:0}.dash-top-customer-head{justify-content:space-between;gap:.75rem;margin-bottom:.45rem;font-size:.9rem;display:flex}.dash-top-customer-head strong{min-width:0}.dash-panel-production{background:linear-gradient(#fff 0%,#fafafa 100%)}.dash-soon-badge{color:var(--red);text-transform:uppercase;letter-spacing:.04em;background:#c628281a;border-radius:999px;padding:.3rem .65rem;font-size:.72rem;font-weight:800}.dash-production-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.dash-production-grid-four{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-production-stat{background:#f7f8fa;border-radius:12px;padding:.7rem .75rem}.dash-production-stat span{letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted);font-size:11px;font-weight:700;display:block}.dash-production-stat strong{margin-top:.25rem;font-size:1.05rem;display:block}.dash-production-stat-active{background:#c6282814;border:1px solid #c628281f}.dash-production-stat-active strong{color:var(--red)}.dash-panel-purchasing{background:linear-gradient(#fff 0%,#fffaf7 100%)}.dash-purchasing-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.dash-production-note{color:var(--gray-600);margin:.95rem 0 0;font-size:.82rem;line-height:1.5}@media (width<=639px){.dash-purchasing-stats{grid-template-columns:1fr}}.dash-activity-list{flex-direction:column;gap:.45rem;margin:0;padding:0;list-style:none;display:flex}.dash-activity-compact .dash-activity-item{border-radius:10px;gap:.55rem;padding:.55rem .65rem}.dash-activity-compact .dash-activity-icon{border-radius:8px;width:30px;height:30px;font-size:.62rem}.dash-activity-compact .dash-activity-content strong{font-size:.82rem}.dash-activity-compact .dash-activity-customer,.dash-activity-compact .dash-activity-date{font-size:.72rem}.dash-activity-compact .dash-activity-amount{font-size:.78rem}.dash-activity-compact .dash-panel-header{margin-bottom:.65rem}.dash-activity-item{border:1px solid var(--color-border);background:#f8f9fb;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:.65rem;padding:.65rem .75rem;display:grid}.dash-activity-icon{width:38px;height:38px;color:var(--white);border-radius:12px;place-items:center;font-size:.68rem;font-weight:800;display:grid}.dash-activity-icon.tone-red{background:var(--red)}.dash-activity-icon.tone-dark{background:var(--black)}.dash-activity-icon.tone-gray{background:#616161}.dash-activity-icon.tone-green{background:#2e7d32}.dash-activity-content strong{font-size:.88rem;display:block}.dash-activity-customer,.dash-activity-date{color:var(--gray-600);margin-top:.12rem;font-size:.76rem;display:block}.dash-activity-amount{color:var(--black);white-space:nowrap;font-size:.84rem;font-weight:800}.dash-empty-inline{color:var(--gray-600);padding:.75rem 0;font-size:.9rem}.dash-error-card{background:var(--white);text-align:center;border:1px solid #c6282840;border-radius:22px;padding:2rem 1.35rem;box-shadow:0 16px 38px #0000000d}.dash-error-card h2{margin:0 0 .5rem}.dash-section-title{margin-top:.25rem}.dash-skeleton{background:linear-gradient(90deg,#ececec 25%,#f5f5f5 50%,#ececec 75%) 0 0/200% 100%;border-radius:10px;animation:1.2s infinite dash-shimmer}.dash-skeleton-title{width:60%;height:28px;margin-bottom:.75rem}.dash-skeleton-text{width:40%;height:16px}.dash-skeleton-label{width:55%;height:12px;margin-bottom:.75rem}.dash-skeleton-value{width:70%;height:28px}.dash-kpi-card-loading,.dash-panel-loading,.dash-hero-loading{min-height:110px}.dash-panel-loading{min-height:280px}@keyframes dash-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width>=640px){.dash-kpi-primary-grid,.dash-kpi-secondary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-production-grid-four{grid-template-columns:repeat(4,minmax(0,1fr))}.dash-activity-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-hero-premium,.dash-hero-executive{grid-template-columns:1fr auto;align-items:center}.dash-hero-subtitle{white-space:normal}}@media (width>=900px){.dash-grid-two,.dash-grid-two-wide{grid-template-columns:1.45fr 1fr}.dash-kpi-primary-grid,.dash-kpi-secondary-grid,.dash-activity-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width>=768px) and (width<=1023px){.sidebar-brand-copy,.sidebar-group-title,.sidebar-link-label,.sidebar-user-copy,.btn-sidebar-logout{display:none}.sidebar-brand{justify-content:center;padding-inline:.65rem}.sidebar-link{justify-content:center;padding-inline:.55rem}.sidebar-footer{justify-content:center;padding-inline:.55rem;display:flex}.sidebar-user{margin-bottom:0}}@media (width<=767px){.app-drawer,.sidebar-backdrop{display:block}.drawer-open .sidebar-backdrop{opacity:1}.dash-hero-premium,.dash-hero-executive{padding:1.25rem}.dash-kpi-primary-grid,.dash-kpi-secondary-grid{gap:.85rem}.dash-activity-item{grid-template-columns:auto 1fr}.dash-activity-amount{grid-column:2;justify-self:start;margin-top:.15rem}.dash-production-grid{grid-template-columns:1fr}.module-hero{flex-direction:column;align-items:flex-start}}.module-page{gap:.875rem}.module-hero{background:linear-gradient(135deg, var(--color-dark) 0%, #171717 55%, #2a1010 100%);color:var(--white);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);max-width:var(--list-max);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;width:100%;margin:0 auto;padding:1rem 1.15rem;display:flex}.module-hero h2{margin:.25rem 0 0;font-size:clamp(1.15rem,2vw,1.5rem)}.module-hero-subtitle{color:#d4d4d4;margin:.35rem 0 0;font-size:.92rem}.module-card{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);max-width:var(--list-max);width:100%;margin:0 auto;padding:1rem 1.1rem}.module-card-muted{background:#fafafa}.module-list-card{border-radius:18px}.po-meta-row{color:var(--gray-600);flex-wrap:wrap;gap:.75rem 1.25rem;margin:.35rem 0;font-size:.88rem;display:flex}.po-grand-total{color:var(--black);margin:.35rem 0;font-weight:800}.status-active{color:#2e7d32;background:#2e7d321f}.status-inactive{color:var(--gray-600);background:#00000014}.status-low-stock{color:#e65100;background:#ff980026}.status-normal-stock{color:#2e7d32;background:#2e7d321f}.tx-type{letter-spacing:.02em;border-radius:4px;padding:.15rem .45rem;font-size:.75rem;font-weight:700;display:inline-block}.tx-type-in{color:#2e7d32;background:#2e7d321f}.tx-type-out{color:var(--red);background:#c628281f}.tx-type-adjustment{color:#1565c0;background:#1976d21f}.dash-panel-inventory{border-left:3px solid #e65100}.dash-inventory-alerts{flex-direction:column;gap:.65rem;margin:0;padding:0;list-style:none;display:flex}.dash-inventory-alert-item{color:inherit;background:#ff980014;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.65rem .75rem;text-decoration:none;display:flex}.dash-inventory-alert-item:hover{background:#ff980024}.dash-inventory-alert-name{color:var(--black);font-weight:600;display:block}.dash-inventory-alert-meta{color:var(--gray-600);margin-top:.15rem;font-size:.82rem;display:block}.dash-inventory-alert-badge{color:#e65100;background:#e6510026;border-radius:999px;flex-shrink:0;padding:.2rem .45rem;font-size:.72rem;font-weight:700}.status-po-draft{color:var(--black);background:#00000014}.status-po-sent{color:var(--red);background:#c628281f}.status-po-partially_received{color:#e65100;background:#ff980026}.status-po-received{color:#2e7d32;background:#2e7d321f}.status-po-cancelled{color:var(--gray-600);background:#00000014}.checkbox-row{align-items:center;gap:.5rem;font-size:.92rem;display:flex}.dash-purchasing-stats-four{grid-template-columns:repeat(4,minmax(0,1fr))}.dash-purchasing-total{background:#c628280f;border:1px solid #c628281f;border-radius:14px;justify-content:space-between;align-items:center;gap:1rem;margin-top:.85rem;padding:.85rem 1rem;display:flex}.dash-purchasing-total span{color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem}.dash-purchasing-total strong{color:var(--red);font-size:1rem}.wo-page{gap:.75rem}.wo-hero-card,.wo-actions-card,.wo-status-card,.wo-info-card,.wo-edit-card{padding:.85rem 1rem}.wo-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-600);margin:0 0 .65rem;font-size:.72rem;font-weight:700}.wo-field-label{text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);margin-bottom:.35rem;font-size:.72rem;font-weight:700;display:block}.wo-status-select{border:1px solid var(--gray-300);background:var(--white);border-radius:10px;width:100%;min-height:44px;padding:.65rem .75rem;font-size:.9rem;font-weight:600}.wo-saving-hint{margin:.35rem 0 0;font-size:.78rem}.wo-action-stack{flex-direction:column;gap:.5rem;width:100%;display:flex}.wo-form-actions{margin-top:.25rem}.btn-block{box-sizing:border-box;text-align:center;justify-content:center;align-items:center;width:100%;min-height:44px;display:flex}@media (width<=767px){.wo-page .compact-card-actions{flex-direction:column;align-items:stretch;gap:.5rem;padding-top:.15rem}.wo-page .compact-card-actions .btn,.wo-page .compact-card-actions .btn-block-mobile{justify-content:center;width:100%;min-height:44px;padding:.55rem .75rem;font-size:.85rem}.wo-page .compact-card{overflow:visible}.wo-page .list-toolbar-filters{grid-template-columns:1fr}}@media (width>=768px){.wo-actions-card .wo-action-stack{flex-flow:wrap}.wo-actions-card .btn-block{width:auto;min-width:10rem}.wo-form-actions .btn-block{width:auto;min-width:12rem}.compact-card-actions .btn-block-mobile{width:auto;min-height:auto}}.wo-tabs{background:var(--gray-100);border-radius:10px;gap:.35rem;padding:.15rem;display:flex}.wo-tab{color:var(--gray-600);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:.55rem .75rem;font-size:.85rem;font-weight:700}.wo-tab.active{background:var(--white);color:var(--black);box-shadow:0 1px 3px #00000014}.wo-materials-card{padding:.85rem 1rem}.wo-materials-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;display:flex}.wo-materials-header h3{margin:0}.wo-materials-actions{flex-wrap:wrap;gap:.5rem;display:flex}.wo-material-form,.wo-material-edit-form{background:var(--gray-100);border-radius:8px;margin-bottom:.85rem;padding:.75rem}.wo-material-pending{margin-top:.15rem;font-size:.78rem;display:block}.wo-material-row-actions{flex-wrap:wrap;gap:.35rem;display:flex}.wo-material-edit-actions{gap:.5rem;display:flex}.wo-materials-table td{vertical-align:top}.wo-costing-card{padding:.85rem 1rem}.wo-costing-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;margin-bottom:.85rem;display:grid}.wo-costing-summary-item{background:var(--gray-100);border-radius:8px;padding:.65rem .75rem}.wo-costing-summary-item span{text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);margin-bottom:.2rem;font-size:.72rem;font-weight:700;display:block}.wo-costing-summary-item strong{color:var(--black);font-size:1rem}.wo-costing-summary-total{background:#c6282814;grid-column:1/-1}.wo-costing-summary-total strong{color:var(--red)}.wo-costing-calculated-at{margin:0 0 .75rem;font-size:.78rem}.wo-costing-breakdown-title{margin:0 0 .65rem;font-size:.95rem}@media (width>=768px){.wo-costing-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.wo-costing-summary-total{grid-column:auto}}.wo-profit-card .wo-profit-summary{margin-bottom:.75rem}.wo-profit-highlight strong{font-size:1.05rem}.wo-profit-value-positive strong,.wo-profit-value-positive{color:#2e7d32}.wo-profit-value-neutral strong,.wo-profit-value-neutral{color:#757575}.wo-profit-value-negative strong,.wo-profit-value-negative{color:#c62828}.wo-profit-status-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:.75rem;margin-top:.5rem;padding-top:.75rem;font-size:.88rem;display:flex}.wo-profit-status-badge{border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.75rem;font-weight:600;display:inline-flex}.wo-profit-status-excellent{color:#2e7d32;background:#2e7d321f}.wo-profit-status-good{color:#388e3c;background:#388e3c1a}.wo-profit-status-warning{color:#ef6c00;background:#f57c001f}.wo-profit-status-low{color:#616161;background:#7575751f}.wo-profit-status-loss{color:#c62828;background:#c628281f}.wo-profit-hint{margin:.5rem 0 0;font-size:.78rem}.profit-report-page .profit-report-hero h2{margin:.15rem 0 .35rem}.profit-report-filter-grid{gap:.75rem;display:grid}.profit-report-filter-grid label{flex-direction:column;gap:.35rem;font-size:.85rem;display:flex}.profit-report-filter-action{align-items:flex-end;display:flex}.profit-report-summary,.profit-report-table-card{margin-top:.75rem}.dash-panel-profit .dash-panel-header{align-items:center}.dash-panel-profit-list .dash-profit-wo-list{margin:0;padding:0;list-style:none}.dash-profit-wo-item{border-bottom:1px solid var(--border);color:inherit;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 0;text-decoration:none;display:flex}.dash-profit-wo-item:last-child{border-bottom:none}.dash-profit-wo-item strong{font-size:.92rem;display:block}.dash-profit-wo-item span{color:var(--muted);font-size:.78rem;display:block}.dash-profit-wo-metrics{text-align:right;font-weight:600}.dash-profit-wo-metrics small{font-size:.75rem;font-weight:500;display:block}.dash-profit-tone-positive{color:#2e7d32}.dash-profit-tone-neutral{color:#757575}.dash-profit-tone-negative{color:#c62828}@media (width>=768px){.profit-report-filter-grid,.wo-profit-summary.wo-costing-summary{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=767px){.wo-materials-header{flex-direction:column}.wo-materials-actions{width:100%}.wo-materials-actions .btn{flex:1}}.wo-labor-card{padding:.85rem 1rem}.wo-labor-summary{background:#1976d214;border-radius:8px;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.65rem .75rem;display:flex}.wo-labor-summary span{text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);font-size:.72rem;font-weight:700}.wo-labor-summary strong{color:#1565c0;font-size:1rem}.wo-labor-table td{vertical-align:top}.wo-overhead-card{padding:.85rem 1rem}.wo-overhead-summary{background:#7b1fa214;border-radius:8px;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.65rem .75rem;display:flex}.wo-overhead-summary span{text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);font-size:.72rem;font-weight:700}.wo-overhead-summary strong{color:#7b1fa2;font-size:1rem}.wo-overhead-table td{vertical-align:top}
