:root{color:#17212b;font-synthesis:none;text-rendering:optimizelegibility;background:#eef2f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{color:#fff;cursor:pointer;background:#0f766e;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:10px 14px;font-weight:700;display:inline-flex}button:hover{filter:brightness(.97)}button:disabled{cursor:not-allowed;opacity:.55;filter:none}input,select,textarea{color:#17212b;background:#fff;border:1px solid #d5dee6;border-radius:8px;width:100%;min-height:42px;padding:10px 12px}input:focus,select:focus,textarea:focus{border-color:#0000;outline:none;box-shadow:0 0 0 2px #28b5a8}textarea{resize:vertical;min-height:86px}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #e5ebf0;padding:12px 10px;font-size:14px}th{color:#5a6875;text-transform:uppercase;font-size:12px}.sort-header{color:#5a6875;text-transform:uppercase;background:0 0;border-radius:4px;justify-content:flex-start;gap:5px;min-height:0;padding:0;font-size:12px}.sort-header:hover,.sort-header.active{color:#0f766e;filter:none}.sort-header span{color:#0f766e;font-size:10px}.table-wrap{width:100%;overflow-x:auto}.table-meta{color:#667581;margin-top:4px;font-size:12px;display:block}.table-photo{color:#667581;background:#eef2f5;border:1px solid #d5dee6;border-radius:8px;width:58px;height:46px;min-height:46px;padding:0;overflow:hidden}.table-photo img{object-fit:cover;width:100%;height:100%}.table-photo.empty{place-items:center;display:grid}.table-thumbs{flex-wrap:wrap;gap:6px;min-width:130px;display:flex}.image-modal{background:#f5f8fa;border:1px solid #dfe7ee;border-radius:8px;place-items:center;min-height:280px;display:grid;overflow:hidden}.image-modal img{object-fit:contain;max-width:100%;max-height:72vh;display:block}.auth-shell{background:linear-gradient(135deg,#eef2f5 0%,#d7efe6 48%,#f2efe6 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:#ffffffeb;border:1px solid #dfe7ee;border-radius:14px;width:min(440px,100%);padding:28px;box-shadow:0 24px 70px #22324029}.auth-card h1{text-align:center;margin:12px 0 4px;font-size:32px}.brand-mark{color:#fff;background:#0f766e;border-radius:12px;place-items:center;width:54px;height:54px;display:grid}.auth-card .brand-mark{margin:0 auto}.auth-subtitle{color:#667581;text-align:center;margin:0 0 18px;font-weight:700}.stack{gap:12px;display:grid}.error{color:#b42318;background:#fff0ee;border:1px solid #ffd4ce;border-radius:8px;margin:0;padding:10px}.muted{color:#667581}.loading{place-items:center;min-height:100vh;font-weight:800;display:grid}.app{grid-template-columns:280px 1fr;min-height:100vh;display:grid}aside{color:#e8edf1;background:#162029;flex-direction:column;gap:22px;padding:20px;display:flex}.logo{border-bottom:1px solid #ffffff1f;align-items:center;gap:12px;padding-bottom:14px;display:flex}.logo svg{color:#7dd3c7}.logo span{color:#a8b6c1;margin-top:3px;font-size:13px;display:block}nav{gap:6px;display:grid}nav a{color:#cad5dc;border-radius:8px;align-items:center;gap:10px;padding:11px 12px;font-weight:700;text-decoration:none;display:flex}nav a.active,nav a:hover{color:#fff;background:#26323d}.workspace{flex-direction:column;min-width:0;display:flex}.workspace>header{background:#fff;border-bottom:1px solid #dfe7ee;justify-content:flex-end;align-items:center;height:64px;padding:0 28px;display:flex}.workspace>header span{color:#667581;text-align:right;font-size:13px;display:block}.route-view{animation:.2s ease-out both route-in}@keyframes route-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page{gap:20px;padding:28px;display:grid}.page-head{justify-content:space-between;align-items:center;gap:16px;display:flex}h1,h2,h3{letter-spacing:0;margin:0}h1{font-size:28px}h2{font-size:18px}.stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.stat,.panel,.product{background:#fff;border:1px solid #dfe7ee;border-radius:8px;box-shadow:0 10px 28px #29384612}.stat{gap:8px;padding:18px;display:grid}.stat span{color:#667581;font-size:13px;font-weight:700}.stat strong{font-size:26px}.two-col,.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.settings-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.panel{padding:18px;overflow:hidden}.panel h2{margin-bottom:12px}.row{border-bottom:1px solid #e8edf1;justify-content:space-between;gap:12px;padding:12px 0;display:flex}.row:last-child{border-bottom:0}.row span{color:#667581}.toolbar{background:#fff;border:1px solid #dfe7ee;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.toolbar input{border:0;min-height:30px;padding:6px 8px}.toolbar input:focus{border-color:#0000;border-radius:6px;box-shadow:0 0 0 3px #9bd8cfa6}.product-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.product{display:grid;overflow:hidden}.photo{aspect-ratio:16/10;color:#667581;background:#dfe7ee;place-items:center;display:grid}.photo img{object-fit:cover;width:100%;height:100%}.product>div:not(.photo),.photos,.actions{padding:14px}.product p{color:#667581;margin:6px 0}.pill{color:#0f766e;background:#dff6f0;border-radius:999px;margin-left:8px;padding:4px 8px;font-size:12px;font-weight:800;display:inline-flex}.pill.danger{color:#b42318;background:#ffe6e1}.photos{border-top:1px solid #e8edf1;flex-wrap:wrap;gap:8px;display:flex}.thumb{color:#667581;background:#eef2f5;border:2px solid #0000;width:44px;height:44px;padding:0;overflow:hidden}.thumb.active{border-color:#0f766e}.thumb img{object-fit:cover;width:100%;height:100%}.thumb input,.file-btn input{display:none}.actions{border-top:1px solid #e8edf1;justify-content:flex-end;gap:8px;display:flex}.secondary,.ghost{color:#17212b;background:#eef2f5}.ghost{justify-content:flex-start;width:100%}.danger-btn{color:#fff;background:#b42318}.modal-backdrop{z-index:20;background:#0a12198a;place-items:center;padding:20px;animation:.18s ease-out both modal-backdrop-in;display:grid;position:fixed;inset:0}.modal-backdrop.closing{pointer-events:none;animation:.18s ease-in both modal-backdrop-out}.modal{background:#fff;border-radius:12px;width:min(760px,100%);max-height:min(90vh,860px);padding:20px;animation:.18s ease-out both modal-in;overflow:auto;box-shadow:0 30px 90px #00000040}.modal.closing{animation:.18s ease-in both modal-out}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes modal-in{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modal-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(8px)scale(.98)}}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.form-grid textarea,.form-grid button,.form-grid .check{grid-column:1/-1}.field{gap:6px;display:grid}.field span{color:#5a6875;font-size:12px;font-weight:800}.input-group{align-items:stretch;width:100%;display:flex}.input-group input{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>span{color:#17212b;background:#eef2f5;border:1px solid #d5dee6;border-left:0;border-radius:0 8px 8px 0;justify-content:center;align-items:center;min-width:58px;padding:0 12px;font-size:13px;font-weight:800;display:inline-flex}.amount-group{grid-template-columns:minmax(0,1fr) 72px 52px;align-items:stretch;width:100%;display:grid}.amount-group input{border-radius:0}.amount-group input:first-child{border-top-left-radius:8px;border-bottom-left-radius:8px}.amount-group input+input{border-left:0}.amount-group>span{color:#17212b;background:#eef2f5;border:1px solid #d5dee6;border-left:0;border-radius:0 8px 8px 0;justify-content:center;align-items:center;padding:0 12px;font-size:13px;font-weight:800;display:inline-flex}.photo-picker{background:#f8fafb;border:1px solid #dfe7ee;border-radius:8px;grid-column:1/-1;gap:10px;padding:12px;display:grid}.photo-picker-head{color:#5a6875;justify-content:space-between;gap:12px;font-size:12px;font-weight:800;display:flex}.photo-preview-list{flex-wrap:wrap;gap:10px;display:flex}.photo-preview,.photo-add{color:#5a6875;background:#fff;border:1px solid #d5dee6;border-radius:8px;width:76px;height:76px;padding:0;position:relative;overflow:hidden}.photo-preview.selected{border:2px solid #0f766e}.photo-preview img{object-fit:cover;width:100%;height:100%}.photo-cover{color:#fff;background:0 0;border-radius:0;width:100%;height:100%;min-height:0;padding:0;display:block}.photo-cover span{color:#fff;text-align:center;background:#0f766ee6;border-radius:6px;padding:3px 4px;font-size:10px;font-weight:800;position:absolute;bottom:4px;left:4px;right:4px}.photo-remove{color:#fff;background:#17212bb8;border-radius:999px;width:22px;height:22px;min-height:22px;padding:0;position:absolute;top:4px;right:4px}.photo-add{cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;font-size:11px;font-weight:800;display:inline-flex}.photo-add input{display:none}.check{align-items:center;gap:8px;display:flex}.check input{width:auto;min-height:auto}.file-btn{color:#fff;cursor:pointer;background:#0f766e;border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-weight:800;display:inline-flex}@media (width<=900px){.app{grid-template-columns:1fr}aside{position:static}.stats,.two-col,.settings-grid,.form-grid{grid-template-columns:1fr}}.modal-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.modal-close{color:#17212b;background:#eef2f5;border-radius:8px;width:36px;height:36px;min-height:36px;padding:0}.modal-actions{grid-column:1/-1;justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.modal-actions button{min-width:120px}.stack .modal-actions{margin-top:8px}.modal-message{color:#4c5c68;white-space:pre-wrap;margin:0 0 18px;line-height:1.5}.typed-confirm{color:#4c5c68;gap:8px;margin-bottom:18px;display:grid}.typed-confirm b{color:#b42318}.icon-btn{flex:none;width:38px;height:38px;min-height:38px;padding:0}.table-actions{justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.report-actions{align-items:center;gap:10px;display:inline-flex}.tabs{background:#fff;border:1px solid #dfe7ee;border-radius:8px;align-items:center;gap:8px;width:fit-content;padding:6px;display:inline-flex}.tabs button{color:#5a6875;background:0 0;min-height:36px;padding:8px 12px}.tabs button.active{color:#fff;background:#0f766e}.report-surface{background:#fff;border:1px solid #dfe7ee;border-radius:8px;gap:16px;padding:18px;display:grid;box-shadow:0 10px 28px #29384612}.report-title{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.report-title p{margin:6px 0 0}.report-title>span{color:#667581;white-space:nowrap;font-size:13px}.report-filters{grid-template-columns:180px 180px 220px minmax(220px,1fr);align-items:end;gap:12px;display:grid}.report-filters label{gap:6px;display:grid}.report-filters span{color:#5a6875;font-size:12px;font-weight:800}.dense-table th,.dense-table td{padding:10px 8px;font-size:13px}tfoot td{background:#f8fafb}@media print{body{background:#fff}aside,.workspace>header,.page-head,.tabs,.no-print{display:none!important}.app,.workspace{min-height:auto;display:block}.page{padding:0;display:block}.report-surface{box-shadow:none;border:0;padding:0}.report-surface:not(.printable){display:none}th,td{color:#111;border-color:#ddd}}
