:root{--paper: #ffffff;--paper-2: #f0f0f3;--surface: #ffffff;--surface-2: #f6f6f8;--ink: #1b1b1f;--ink-2: #55555d;--ink-3: #8a8a93;--line: #ececef;--line-strong: #dcdce1;--accent: #b21f2b;--accent-2: #8c1822;--accent-soft: #f7e1e2;--accent-ink: #6e1219;--teal: #2c7a96;--teal-2: #226176;--teal-soft: #dcecf1;--pos: #2f7d52;--pos-soft: #e2efe6;--neg: #b21f2b;--neg-soft: #f7e1e2;--warn: #b8860b;--warn-soft: #f6ecd2;--info: #2c7a96;--info-soft: #dcecf1;--ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--display: var(--ui);--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--r-sm: 8px;--r: 12px;--r-lg: 20px;--shadow-sm: 0 1px 2px rgba(20, 20, 30, .05);--shadow-input: 0 1px 2px rgba(20, 20, 30, .07);--shadow: 0 1px 3px rgba(20, 20, 30, .05), 0 12px 28px -16px rgba(20, 20, 35, .26);--shadow-pop: 0 1px 3px rgba(20, 20, 30, .06), 0 14px 30px -14px rgba(20, 20, 35, .3);--shadow-lg: 0 24px 60px -28px rgba(15, 15, 30, .4);--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--nav-w: 252px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--ui);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}*{-webkit-tap-highlight-color:transparent}.table-wrap,.modal,.drawer,.page{-webkit-overflow-scrolling:touch}@media (hover: none){.btn:hover,.nav-item:hover,table.tbl tbody tr:hover{background:inherit}}h1,h2,h3,h4{font-family:var(--display);font-weight:700;margin:0;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button{font-family:inherit}.mono{font-family:var(--mono)}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.app{display:grid;grid-template-columns:var(--nav-w) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:linear-gradient(180deg,var(--surface),var(--surface-2));padding:22px 16px;display:flex;flex-direction:column;gap:4px}.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 20px;margin-bottom:8px;border-bottom:1px solid var(--line)}.brand .mark{width:42px;height:42px;flex:none;position:relative;display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:700;font-size:16px}.brand .mark:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:7px;background:linear-gradient(145deg,#c8303d,var(--accent) 55%,var(--accent-2));transform:rotate(45deg);box-shadow:inset 0 1px #ffffff59,var(--shadow-sm)}.brand .mark span{position:relative;z-index:1;letter-spacing:-.02em}.brand-logo{height:46px;width:auto;display:block}.login-brand{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:18px}.login-logo{height:66px;width:auto}.login-sub{font-size:11px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase}.brand .word{line-height:1.1}.brand .word b{font-family:var(--display);font-size:18px;display:block;letter-spacing:-.02em}.brand .word span{font-size:11px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase}.nav-group-label{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding:16px 10px 6px;font-weight:700}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--ink-2);font-weight:500;font-size:14px;transition:background .15s,color .15s}.nav-item .ic{width:18px;height:18px;flex:none;opacity:.8}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600;box-shadow:inset 0 0 0 1px #b6532b29}.nav-item.active .ic{opacity:1}.nav-spacer{flex:1}.nav-user{margin-top:8px;padding:10px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:50%;flex:none;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-weight:600;font-size:13px}.main{min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:18px 28px;background:linear-gradient(180deg,#c8303d,var(--accent));border-bottom:none;box-shadow:0 6px 20px -8px #b21f2b8c;color:#fff}.topbar .page-title{color:#fff}.topbar .page-sub{color:#ffffffeb}.topbar .btn{color:#fff;background:#ffffff24;border-color:#fff6;box-shadow:none}.topbar .btn:hover{background:#ffffff3d;border-color:#fff9}.topbar .btn.ghost{background:transparent;border-color:transparent}.topbar .btn.ghost:hover{background:#ffffff29}.topbar .btn.primary{background:#fff;color:var(--accent);border-color:#fff}.topbar .btn.primary:hover{background:#fff;opacity:.92}.topbar-titlebox{flex:1;min-width:0}.topbar .page-title{font-size:24px;font-weight:700;letter-spacing:-.02em;color:#fff;overflow:hidden;text-overflow:ellipsis}.topbar .page-sub{color:#ffffffeb;font-size:13px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-btn .ic{width:24px;height:24px}.topbar-actions{margin-left:auto;display:flex;gap:10px;align-items:center}.page{padding:26px 28px 80px;max-width:1180px;width:100%}.page-narrow{max-width:820px}.menu-btn,.mobile-nav{display:none}.card{background:var(--surface);border:1px solid #f1f1f4;border-radius:var(--r-lg);box-shadow:var(--shadow)}.card-pad{padding:20px}.card-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}.card-head h3{font-size:17px}.card-head .sub{color:var(--ink-3);font-size:12.5px}.card-head .right{margin-left:auto;display:flex;gap:8px;align-items:center}.grid{display:grid;gap:16px}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.split{display:grid;gap:16px;grid-template-columns:1.6fr 1fr}.stat{padding:18px 20px;position:relative;overflow:hidden}.stat-row{display:flex;align-items:center;gap:14px}.stat-main{flex:1;min-width:0}.stat .spark{flex:none;align-self:center;opacity:.95}.stat-ic{width:50px;height:50px;border-radius:15px;flex:none;display:grid;place-items:center;background:var(--surface-2);color:var(--ink-3)}.stat-ic .ic{width:24px;height:24px}.stat.pos .stat-ic{background:var(--pos-soft);color:var(--pos)}.stat.neg .stat-ic{background:var(--neg-soft);color:var(--neg)}.stat.info .stat-ic{background:var(--teal-soft);color:var(--teal)}@media (max-width: 380px){.stat .spark{display:none}}.stat .label{font-size:12px;color:var(--ink-3);font-weight:600;letter-spacing:.03em;text-transform:uppercase}.stat .value{font-family:var(--display);font-size:30px;font-weight:700;margin-top:8px;letter-spacing:-.03em;white-space:nowrap}.stat .value small{font-size:16px;color:var(--ink-3);font-weight:500}.stat .delta{margin-top:8px;font-size:12.5px;display:inline-flex;gap:5px;align-items:center}.stat .accent-bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.stat.pos .accent-bar{background:var(--pos)}.stat.neg .accent-bar{background:var(--neg)}.stat.info .accent-bar{background:var(--info)}.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-weight:600;font-size:13.5px;padding:9px 15px;border-radius:10px;cursor:pointer;transition:transform .08s,background .15s,border-color .15s,box-shadow .15s;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--ink-3)}.btn:active{transform:translateY(1px)}.btn .ic{width:16px;height:16px}.btn.primary{background:linear-gradient(180deg,#c8303d,var(--accent));color:#fff;border-color:var(--accent-2);box-shadow:0 1px #ffffff38 inset,var(--shadow-sm)}.btn.primary:hover{background:linear-gradient(180deg,#be2733,var(--accent-2))}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:var(--surface-2)}.btn.danger{color:var(--neg);border-color:var(--neg-soft)}.btn.danger:hover{background:var(--neg-soft);border-color:var(--neg)}.btn.danger.fill{background:var(--neg);color:#fff;border-color:var(--accent-2);box-shadow:0 1px #fff3 inset,var(--shadow-sm)}.btn.danger.fill:hover{background:var(--accent-2)}.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px}.btn.icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}.badge.pos{background:var(--pos-soft);color:var(--pos);border-color:transparent}.badge.neg{background:var(--neg-soft);color:var(--neg);border-color:transparent}.badge.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}.badge.info{background:var(--info-soft);color:var(--info);border-color:transparent}.badge.accent{background:var(--accent-soft);color:var(--accent-ink);border-color:transparent}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}table.tbl th{text-align:left;font-weight:600;color:var(--ink-3);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap}table.tbl td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}table.tbl tr:last-child td{border-bottom:none}table.tbl tbody tr{transition:background .12s}table.tbl tbody tr:hover{background:var(--surface-2)}.t-right{text-align:right}.t-center{text-align:center}.t-name{font-weight:600}.t-muted{color:var(--ink-3)}.row-click{cursor:pointer}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--ink-2)}.field .hint{font-size:11.5px;color:var(--ink-3)}.input,.select,textarea.input{font-family:inherit;font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;padding:10px 12px;width:100%;box-shadow:var(--shadow-input);transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input.num{font-variant-numeric:tabular-nums}.input-prefix{position:relative}.input-prefix .pfx{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-size:13px}.input-prefix .input{padding-left:38px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stepper{display:flex;align-items:center;gap:6px}.stepper .step{width:36px;height:40px;flex:none;border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;font-size:18px;font-weight:600;color:var(--ink-2);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-input)}.stepper .step:hover{background:var(--surface-2)}.stepper .step:active{transform:translateY(1px)}.stepper .step:disabled{opacity:.4;cursor:not-allowed}.stepper .step.edit{color:var(--ink-3)}.stepper .step.edit .ic{width:15px;height:15px}.stepper .val{flex:1;min-width:0;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid transparent;border-radius:9px;background:var(--surface-2);font:inherit;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);cursor:pointer;padding:0 8px}.stepper .val em{font-style:normal;color:var(--ink-3);font-size:12px;font-weight:500}.stepper input.val{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);cursor:text;outline:none;text-align:center}@media (max-width: 600px){.stepper .step{width:42px;height:44px}.stepper .val{height:44px;font-size:16px}}.line-item{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.line-item .li-mat{grid-column:1 / -1;min-width:0}.line-item .li-qty,.line-item .li-cost{grid-column:1 / -1}.line-item .li-sub{font-size:13px;color:var(--ink-2);white-space:nowrap;align-self:center}.line-item .li-del{justify-self:end}@media (min-width: 600px){.line-item{display:flex;flex-wrap:nowrap;gap:8px;align-items:center}.line-item .li-mat{flex:2 1 0}.line-item .li-qty{flex:1.4 1 150px}.line-item .li-cost{flex:1.2 1 130px}.line-item .li-sub{flex:0 0 auto;min-width:84px;text-align:right}}.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;padding:8px 12px;min-width:200px;box-shadow:var(--shadow-input)}.filters-bar{display:flex;flex-direction:column;gap:10px}.filters-bar .search{width:100%;min-width:0}.filters-bar .sel-wrap,.filters-bar .daterange{width:100%}.filters-bar .sel-wrap.inline .sel-trigger{width:100%;min-width:0}.filters-bar .seg{display:flex}.filters-bar .seg button{flex:1}@media (min-width: 720px){.filters-bar{flex-direction:row;align-items:center}.filters-bar .search{flex:1 1 220px;width:auto}.filters-bar .sel-wrap,.filters-bar .daterange{width:auto}.filters-bar .sel-wrap.inline .sel-trigger{width:auto;min-width:170px}.filters-bar .seg{margin-left:auto}.filters-bar .seg button{flex:none}}.search input{border:none;background:none;outline:none;font:inherit;width:100%}.search .ic{width:16px;height:16px;color:var(--ink-3)}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px;box-shadow:var(--shadow-input)}.seg button{border:none;background:none;padding:7px 13px;border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#281a1057;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:20px;animation:fade .15s ease}.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow:auto;animation:pop .18s cubic-bezier(.2,.9,.3,1.2)}.modal.wide{max-width:760px}.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.modal-head h3{font-size:19px}.modal-head .sub{font-size:12.5px;color:var(--ink-3);margin-top:2px}.modal-body{padding:22px}.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--line);background:var(--surface-2);position:sticky;bottom:0}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.row{display:flex;align-items:center;gap:10px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.wrap-gap{display:flex;flex-wrap:wrap;gap:10px}.muted{color:var(--ink-3)}.tiny{font-size:12px}.w-auto{width:auto}.flex-1{flex:1}.mt-2{margin-top:var(--s-2)}.mt-3{margin-top:var(--s-3)}.mb-2{margin-bottom:var(--s-2)}.mb-3{margin-bottom:var(--s-3)}.mb-4{margin-bottom:var(--s-4)}.mb-5{margin-bottom:var(--s-5)}.fs-sm{font-size:13px}.fs-lg{font-size:18px}.money{font-family:var(--display);font-variant-numeric:tabular-nums;font-weight:600}.money.pos{color:var(--pos)}.money.neg{color:var(--neg)}.divider{height:1px;background:var(--line);margin:16px 0}.empty{text-align:center;padding:48px 20px;color:var(--ink-3)}.empty .big{font-family:var(--display);font-size:19px;color:var(--ink-2);margin-bottom:6px}.stagger>*{opacity:0;animation:rise .5s cubic-bezier(.2,.7,.3,1) forwards}.stagger>*:nth-child(1){animation-delay:.02s}.stagger>*:nth-child(2){animation-delay:.07s}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.17s}.stagger>*:nth-child(5){animation-delay:.22s}.stagger>*:nth-child(6){animation-delay:.27s}.bar-track{height:8px;border-radius:999px;background:var(--paper-2);overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3a93b0,var(--teal))}.bar-fill.pos{background:linear-gradient(90deg,#43a06b,var(--pos))}.bar-fill.neg{background:linear-gradient(90deg,#cc424d,var(--neg))}.bar-fill.warn{background:linear-gradient(90deg,#d6a32b,var(--warn))}.toast-wrap{position:fixed;bottom:calc(22px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:90;display:flex;flex-direction:column;gap:8px}.toast{background:var(--ink);color:var(--paper);padding:11px 18px;border-radius:12px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:pop .2s ease}.toast .ic{width:16px;height:16px;color:#7fd1a0}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{display:none}.menu-btn{display:inline-flex}.topbar{padding:12px 16px;flex-wrap:wrap;row-gap:10px}.topbar .page-title{font-size:19px;white-space:nowrap}.topbar-actions{order:3;margin-left:auto;justify-content:flex-end}.topbar-actions .btn.primary{display:none}.topbar-actions:not(:has(.btn:not(.primary))){display:none}.page{padding:18px 16px 96px}.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}.cols-4{grid-template-columns:1fr 1fr}.split,.field-row{grid-template-columns:1fr}.card-head{flex-wrap:wrap}.card-head .right{margin-left:0;width:100%}.toast-wrap{bottom:calc(76px + env(safe-area-inset-bottom))}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--ink-3);padding:4px 8px;border-radius:10px}.mobile-nav a .ic{width:20px;height:20px}.mobile-nav a.active{color:var(--accent)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#281a1066;animation:fade .15s}.drawer{position:fixed;top:0;left:0;bottom:0;width:min(88vw,330px);z-index:71;background:var(--surface);border-right:1px solid var(--line);padding:18px 14px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:6px;animation:slide .2s ease;overflow-y:auto}.drawer .nav-item{padding:13px 14px;font-size:15.5px;gap:14px;border-radius:13px;min-height:50px}.drawer .nav-item .ic{width:22px;height:22px}.drawer .nav-item.active{box-shadow:inset 0 0 0 1px #b21f2b29,inset 4px 0 0 var(--accent)}.drawer .nav-group-label{font-size:11px;letter-spacing:.14em;padding:18px 12px 8px}.drawer .brand{padding-bottom:16px}.drawer .brand .word b{font-size:19px}@keyframes slide{0%{transform:translate(-100%)}}}@media (max-width: 680px){.card:has(table.tbl){border:none;box-shadow:none;background:transparent}.card:has(table.tbl)>.table-wrap{overflow:visible}.card:has(table.tbl) .card-head{padding-left:4px;padding-right:4px;border:none}table.tbl thead{display:none}table.tbl,table.tbl tbody,table.tbl tfoot,table.tbl tr,table.tbl td{display:block;width:100%}table.tbl tr{border:1px solid #ececed;border-radius:var(--r-lg);margin-bottom:14px;padding:4px 2px;background:var(--surface);box-shadow:var(--shadow-pop);overflow:hidden}table.tbl tbody tr:hover{background:var(--surface)}table.tbl td{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:7px 18px;border-bottom:none;text-align:right;font-size:14px;font-weight:500;color:var(--ink)}table.tbl tbody td:nth-child(2){padding-top:14px}table.tbl td:last-child{padding-bottom:14px}table.tbl td:before{content:attr(data-label);text-align:left;white-space:nowrap;color:var(--ink-3);font-size:12.5px;font-weight:500;text-transform:none;letter-spacing:0;flex:none}table.tbl td:first-child{background:transparent;border-bottom:1px solid var(--line);border-radius:0;font-size:16.5px;font-weight:800;justify-content:flex-start;padding:16px 18px 13px;color:var(--ink);letter-spacing:-.02em}table.tbl td:first-child:before{content:""}table.tbl tfoot td{background:var(--surface-2)}}@media (max-width: 600px){.overlay{align-items:flex-end;padding:0}.modal,.modal.wide{max-width:100%;width:100%;border-radius:22px 22px 0 0;max-height:92vh;animation:sheet .3s cubic-bezier(.2,.8,.2,1);padding-bottom:env(safe-area-inset-bottom)}.modal:before{content:"";display:block;width:38px;height:5px;border-radius:3px;background:var(--line-strong);margin:9px auto 2px}.modal-head{padding:12px 20px 14px}.modal-foot{padding-bottom:calc(16px + env(safe-area-inset-bottom))}@keyframes sheet{0%{transform:translateY(100%)}}.input,.select,textarea.input{padding:12px 14px;font-size:16px;border-radius:12px}.input-prefix .input{padding-left:40px}.btn{padding:12px 16px;font-size:15px;border-radius:12px}.btn.sm{padding:9px 13px;font-size:13.5px}.btn.icon{padding:10px;min-width:44px;min-height:44px}.seg button{padding:9px 14px}.nav-item:active,.mobile-nav a:active,table.tbl tbody tr:active,.card.row-click:active,.btn:active{opacity:.65}.mobile-nav{padding-top:10px}.mobile-nav a .ic{width:22px;height:22px}.mobile-nav a{font-size:10.5px;gap:4px}}@media (max-width: 480px){.cols-4{grid-template-columns:1fr}.stat .value{font-size:26px}.page{padding:16px 14px 96px}}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 50% -10%,rgba(178,31,43,.08),transparent 60%),var(--paper)}.login-card{width:100%;max-width:360px;padding:28px 24px calc(24px + env(safe-area-inset-bottom))}.login-err{margin-top:10px;font-size:13px;color:var(--neg);background:var(--neg-soft);padding:8px 12px;border-radius:10px}.splash{min-height:100vh;display:grid;place-items:center;background:var(--paper)}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){::view-transition-old(root){animation:vt-out .2s ease both}::view-transition-new(root){animation:vt-in .26s ease both}}@keyframes vt-out{to{opacity:0;transform:translateY(-6px)}}@keyframes vt-in{0%{opacity:0;transform:translateY(8px)}}.fab{display:none}@media (max-width: 900px){.fab{display:inline-flex;align-items:center;gap:8px;position:fixed;right:16px;z-index:45;bottom:calc(80px + env(safe-area-inset-bottom));padding:14px 20px;border-radius:999px;background:linear-gradient(180deg,#c8303d,var(--accent));color:#fff;border:none;font-weight:700;font-size:15px;box-shadow:0 10px 26px -6px #b21f2b80;cursor:pointer;animation:rise .3s ease}.fab .ic{width:20px;height:20px}.fab:active{transform:translateY(1px);opacity:.9}}.fab-export{position:fixed;right:20px;bottom:24px;z-index:46;width:56px;height:56px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#21a85e,#128c4f);color:#fff;border:none;cursor:pointer;box-shadow:0 12px 26px -8px #128c4f8c;transition:transform .08s}.fab-export .ic{width:24px;height:24px}.fab-export:active{transform:translateY(1px);opacity:.92}@media (max-width: 900px){.fab-export{right:16px;bottom:calc(84px + env(safe-area-inset-bottom))}}.btn.wa{color:#128c4f;border-color:#b9e6cd}.btn.wa:hover{background:#e7f6ee;border-color:#21a85e}.skel{background:linear-gradient(90deg,var(--surface-2) 25%,#eef0f3 37%,var(--surface-2) 63%);background-size:400% 100%;border-radius:8px;animation:shimmer 1.4s ease infinite;display:block}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}@media (prefers-reduced-motion: reduce){.skel{animation:none}}.sel-wrap{position:relative}.sel-wrap.inline{display:inline-block}.sel-wrap.inline .sel-trigger{width:auto;min-width:160px}.sel-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;cursor:pointer}.sel-trigger .chev{width:16px;height:16px;color:var(--ink-3);flex:none;transition:transform .15s}.sel-trigger[aria-expanded=true] .chev{transform:rotate(90deg)}.sel-trigger .ph{color:var(--ink-3)}.sel-trigger .val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sel-pop{position:absolute;z-index:65;left:0;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;max-height:280px;overflow:auto;animation:pop .14s ease}.sel-list{display:flex;flex-direction:column;gap:2px}.sheet-tall{display:flex;flex-direction:column;gap:10px}.sheet-search{flex:none}.sheet-search .search{width:100%;min-width:0}.sel-list.scroll{overflow-y:auto;max-height:56vh}@media (max-width: 600px){.sheet-tall{min-height:52vh}.sel-list.scroll{max-height:64vh}}.sel-opt{display:flex;align-items:center;gap:10px;justify-content:space-between;width:100%;padding:10px 11px;border:none;background:none;border-radius:9px;font:inherit;font-size:14px;color:var(--ink);cursor:pointer;text-align:left}.sel-opt:hover{background:var(--surface-2)}.sel-opt.on{color:var(--accent-ink);font-weight:600;background:var(--accent-soft)}.sel-opt .ic{width:16px;height:16px;color:var(--accent);flex:none}@media (max-width: 600px){.sel-opt{padding:13px 14px;font-size:15px}}.df-trigger{display:inline-flex;align-items:center;gap:8px;cursor:pointer;text-align:left;min-width:150px}.df-trigger.block{width:100%}.df-trigger .ic{width:16px;height:16px;color:var(--ink-3);flex:none}.df-trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.daterange{display:flex;align-items:center;gap:8px;min-width:0}.daterange .df-trigger{flex:1 1 0;min-width:0}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}@media (max-width: 600px){.toolbar>*{width:100%}.toolbar .seg{width:auto}.daterange{width:100%}}.cal{max-width:340px;margin:0 auto}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cal-head .m{font-weight:700;font-size:15px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{text-align:center;font-size:11px;color:var(--ink-3);font-weight:700;padding:4px 0}.cal-day{height:42px;width:100%;border:none;background:none;border-radius:10px;font:inherit;font-size:14px;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center}.cal-day:hover{background:var(--surface-2)}.cal-day.on{background:var(--accent);color:#fff;font-weight:700}.cal-day.today{box-shadow:inset 0 0 0 1.5px var(--accent-soft)}.cal-day.empty{visibility:hidden}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seg-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;flex-wrap:nowrap;scrollbar-width:none}.seg-scroll::-webkit-scrollbar{display:none}.seg-scroll button{white-space:nowrap}.sell-grid{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}.sell-side{position:sticky;top:18px}.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.prod-tile{display:flex;flex-direction:column;gap:6px;text-align:left;min-height:96px;padding:13px 14px;border-radius:15px;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface);box-shadow:var(--shadow-sm);font:inherit;color:var(--ink);transition:transform .08s ease,box-shadow .15s ease,border-color .15s ease}.prod-tile:hover{border-color:var(--accent-2);box-shadow:var(--shadow)}.prod-tile:active{transform:scale(.97)}.prod-tile.is-out{opacity:.55;cursor:not-allowed}.prod-tile-name{font-weight:600;font-size:14px;line-height:1.3}.sell-cart{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.sell-cart .card-head{padding:14px 16px}.sell-lines{padding:6px 12px;display:flex;flex-direction:column;gap:2px;max-height:46vh;overflow-y:auto}.sell-line{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}.sell-line:last-child{border-bottom:none}.qty-step{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border-radius:10px;padding:3px}.qty-step .btn.icon.sm{width:28px;height:28px}.sell-pay{padding:14px 16px;border-top:1px solid var(--line);background:var(--surface-2)}.sell-fab{display:none;position:fixed;left:16px;right:16px;z-index:45;bottom:calc(16px + env(safe-area-inset-bottom));align-items:center;gap:10px;justify-content:center;padding:15px 18px;border:none;border-radius:16px;cursor:pointer;background:var(--accent);color:#fff;font:inherit;font-weight:700;font-size:15px;box-shadow:var(--shadow-lg)}.sell-fab b{margin-left:auto}.sell-sheet{position:fixed;left:0;right:0;bottom:0;z-index:72;background:var(--surface);border-radius:20px 20px 0 0;padding:14px 14px calc(14px + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);animation:sheetup .22s ease;max-height:88vh;overflow-y:auto}@keyframes sheetup{0%{transform:translateY(100%)}}.receipt-ok{width:min(92vw,340px);text-align:center;z-index:61;animation:okpop .2s ease}.ok-circle{width:64px;height:64px;border-radius:50%;margin:0 auto;display:grid;place-items:center;background:var(--pos);color:#fff}@keyframes okpop{0%{transform:scale(.9);opacity:0}}@media (max-width: 900px){.sell-grid{grid-template-columns:1fr}.sell-side{display:none}.sell-fab{display:flex}}.prod-thumb{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;overflow:hidden;background:var(--surface-2);color:var(--muted);margin-right:10px;vertical-align:middle;flex:0 0 auto}.prod-thumb img{width:100%;height:100%;object-fit:cover}.t-name{display:flex;align-items:center}.img-upload{display:flex;align-items:center;gap:12px}.img-drop{display:flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:12px;cursor:pointer;border:1.5px dashed var(--line-strong);background:var(--surface-2);overflow:hidden;text-align:center;padding:6px}.img-drop:hover{border-color:var(--accent)}.img-drop img{width:100%;height:100%;object-fit:cover;border-radius:8px}
