@import"https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";.btn{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-weight:600;border-radius:var(--radius-sm);border:1.5px solid transparent;transition:transform var(--speed-fast) var(--ease),background var(--speed-fast) var(--ease),border-color var(--speed-fast) var(--ease);white-space:nowrap}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--md{padding:.6rem 1.1rem;font-size:var(--text-sm)}.btn--sm{padding:.4rem .8rem;font-size:var(--text-xs)}.btn--primary{background:var(--color-amber);color:var(--color-ink)}.btn--primary:hover:not(:disabled){background:var(--color-amber-dark)}.btn--secondary{background:transparent;border-color:var(--color-ink);color:var(--color-ink)}.btn--secondary:hover:not(:disabled){background:var(--color-ink);color:#fff}.btn--ghost{background:transparent;color:var(--color-graphite)}.btn--ghost:hover:not(:disabled){background:var(--color-mist);color:var(--color-ink)}.btn--danger{background:var(--color-rust);color:#fff}.btn--danger:hover:not(:disabled){background:#a4391f}.btn__spinner{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:spin .7s linear infinite}.field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.field__label{font-size:var(--text-xs);font-weight:600;color:var(--color-graphite);text-transform:uppercase;letter-spacing:.04em}.field__control{border:1.5px solid var(--color-mist);border-radius:var(--radius-sm);padding:.65rem .8rem;font-size:var(--text-base);background:var(--color-surface);color:var(--color-ink);transition:border-color var(--speed-fast) var(--ease)}.field__control:focus{border-color:var(--color-amber)}.field__control--error{border-color:var(--color-rust)}.field__hint{font-size:var(--text-xs);color:var(--color-graphite)}.field__error{font-size:var(--text-xs);color:var(--color-rust)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono);letter-spacing:.02em}.badge--neutral{background:var(--color-mist);color:var(--color-graphite)}.badge--success{background:#3f7d5824;color:var(--color-moss)}.badge--danger{background:#c1442d1f;color:var(--color-rust)}.badge--warning{background:#ffb6272e;color:#93650a}.badge--info{background:#14213d14;color:var(--color-ink)}.spinner-wrap{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-7) 0;color:var(--color-graphite);font-size:var(--text-sm)}.spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid var(--color-mist);border-top-color:var(--color-amber);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-7) var(--space-5);color:var(--color-graphite)}.empty-state__mark{width:40px;height:40px;margin:0 auto var(--space-3);border-radius:50%;border:2px dashed var(--color-mist)}.empty-state h3{font-size:var(--text-md);margin-bottom:var(--space-1)}.empty-state p{margin:0;font-size:var(--text-sm)}.table-card{background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-md);overflow:hidden}.data-table{width:100%}.data-table thead th{text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-graphite);background:var(--color-paper);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-mist);font-weight:600}.data-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border-bottom:1px solid var(--color-mist);color:var(--color-ink)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#ffb6270f}.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-graphite)}.pagination__controls{display:flex;gap:var(--space-2)}.pagination__controls button{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--color-mist);background:var(--color-surface);font-size:var(--text-md);display:flex;align-items:center;justify-content:center}.pagination__controls button:disabled{opacity:.4}.pagination__controls button:not(:disabled):hover{border-color:var(--color-amber)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14213d73;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4);animation:fade-in var(--speed-base) var(--ease)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal--sm{max-width:380px}.modal--md{max-width:560px}.modal--lg{max-width:760px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-5) var(--space-3)}.modal__header h3{font-size:var(--text-lg)}.modal__close{font-size:1.6rem;line-height:1;color:var(--color-graphite)}.modal__body{padding:0 var(--space-5) var(--space-5)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-mist)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap}.page-header h1{font-size:var(--text-xl);font-weight:800}.page-header p{margin:var(--space-1) 0 0;color:var(--color-graphite);font-size:var(--text-sm)}.page-header__actions{display:flex;gap:var(--space-2)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.toolbar__filters{display:flex;gap:var(--space-2);flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:var(--space-2);background:var(--color-surface);border:1.5px solid var(--color-mist);border-radius:var(--radius-sm);padding:.55rem .9rem;min-width:240px}.search-box input{border:none;background:none;outline:none;font-size:var(--text-sm);width:100%;color:var(--color-ink)}.search-box span{color:var(--color-graphite)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-ink);color:#fff;display:flex;flex-direction:column;padding:var(--space-5) var(--space-3);z-index:50}.sidebar__brand{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-2);margin-bottom:var(--space-6)}.sidebar__brand-mark{width:38px;height:38px;border-radius:var(--radius-sm);flex-shrink:0;object-fit:cover;object-position:top center}.sidebar__brand div{display:flex;flex-direction:column;font-family:var(--font-display);line-height:1.15}.sidebar__brand strong{font-size:var(--text-md);font-weight:800}.sidebar__brand span{font-size:var(--text-xs);color:var(--color-amber);letter-spacing:.05em;text-transform:uppercase}.sidebar__nav{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:.65rem var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:#ffffffb8;transition:background var(--speed-fast) var(--ease),color var(--speed-fast) var(--ease);position:relative}.sidebar__link:hover,.sidebar__link--active{background:var(--color-ink-soft);color:#fff}.sidebar__link--active:before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--color-amber)}.sidebar__icon{width:18px;text-align:center;font-size:1rem;color:var(--color-amber)}.sidebar__footer{padding:var(--space-3) var(--space-2) 0;border-top:1px solid var(--color-line)}.sidebar__stripe{display:block;height:4px;border-radius:4px;margin-bottom:var(--space-3);background:repeating-linear-gradient(90deg,var(--color-amber) 0 6px,transparent 6px 11px);opacity:.7}.sidebar__footer p{margin:0;font-size:.7rem;color:#ffffff73}.topbar{height:var(--topbar-height);background:var(--color-paper);border-bottom:1px solid var(--color-mist);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:40}.topbar__user{position:relative}.topbar__avatar-btn{display:flex;align-items:center;gap:var(--space-3)}.topbar__avatar{width:36px;height:36px;border-radius:50%;background:var(--color-ink);color:var(--color-amber);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:var(--text-sm)}.topbar__user-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.topbar__user-info strong{font-size:var(--text-sm);color:var(--color-ink)}.topbar__user-info span{font-size:var(--text-xs);color:var(--color-graphite)}.topbar__menu{position:absolute;right:0;top:calc(100% + var(--space-2));background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:160px;overflow:hidden}.topbar__menu button{width:100%;text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-rust)}.topbar__menu button:hover{background:var(--color-paper)}@media (max-width: 960px){.sidebar{display:none}}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-ink);background-image:radial-gradient(circle at 15% 20%,rgba(201,162,39,.1),transparent 40%),radial-gradient(circle at 85% 80%,rgba(201,162,39,.08),transparent 40%);padding:var(--space-5)}.auth-card{position:relative;background:var(--color-surface);width:100%;max-width:380px;padding:var(--space-7) var(--space-6) var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.auth-card__stripe{position:absolute;top:0;left:0;right:0;height:8px;background:repeating-linear-gradient(90deg,var(--color-amber) 0 4px,var(--color-ink) 4px 6px,var(--color-amber) 6px 9px,var(--color-ink) 9px 10px)}.auth-card__brand{display:flex;justify-content:center;margin-bottom:var(--space-2)}.auth-card__logo{width:132px;border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.auth-card__subtitle{margin:var(--space-4) 0 var(--space-6);color:var(--color-graphite);font-size:var(--text-sm);text-align:center}.auth-card__error{background:#a23b2b1a;color:var(--color-rust);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);margin:0 0 var(--space-4)}.auth-card__submit{width:100%;justify-content:center;margin-top:var(--space-2)}.auth-card__perf{position:absolute;left:0;right:0;bottom:-10px;height:20px;background-image:radial-gradient(circle,var(--color-ink) 9px,transparent 9.5px);background-size:22px 20px;background-repeat:repeat-x;background-position:center;opacity:.9}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.kpi-card{position:relative;background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-md);padding:var(--space-5);overflow:hidden}.kpi-card__stripe{position:absolute;top:0;left:0;right:0;height:5px;background:repeating-linear-gradient(90deg,currentColor 0 5px,transparent 5px 9px)}.kpi-card--amber{color:var(--color-amber-dark)}.kpi-card--moss{color:var(--color-moss)}.kpi-card--rust{color:var(--color-rust)}.kpi-card--ink{color:var(--color-ink)}.kpi-card__label{display:block;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-graphite);margin-top:var(--space-2)}.kpi-card__value{display:block;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--color-ink);margin-top:var(--space-1)}.kpi-card__sublabel{display:block;font-size:var(--text-xs);color:var(--color-graphite);margin-top:var(--space-1);font-family:var(--font-mono)}.dashboard-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr}}.panel{background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-md);padding:var(--space-5)}.panel h2{font-size:var(--text-md);margin-bottom:var(--space-4)}.chart-empty{color:var(--color-graphite);font-size:var(--text-sm);text-align:center;padding:var(--space-7) 0;margin:0}.low-stock-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);max-height:280px;overflow-y:auto}.low-stock-list li{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-mist)}.low-stock-list li:last-child{border-bottom:none;padding-bottom:0}.low-stock-list li div{display:flex;flex-direction:column}.low-stock-list li strong{font-size:var(--text-sm)}.low-stock-list li .mono{font-size:var(--text-xs);color:var(--color-graphite)}.range-select{border:1.5px solid var(--color-mist);border-radius:var(--radius-sm);padding:.5rem .8rem;font-size:var(--text-sm);background:var(--color-surface);color:var(--color-ink)}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-mist);margin-bottom:var(--space-5)}.tab{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:600;color:var(--color-graphite);border-bottom:2px solid transparent;margin-bottom:-1px}.tab--active{color:var(--color-ink);border-bottom-color:var(--color-amber)}.item-rows{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.item-row{display:grid;grid-template-columns:2fr .8fr .8fr .9fr auto;gap:var(--space-2);align-items:end;background:var(--color-paper);padding:var(--space-3);border-radius:var(--radius-sm)}.item-row .field{margin-bottom:0}.item-row__remove{width:34px;height:34px;border-radius:var(--radius-sm);color:var(--color-rust);font-size:1.1rem;border:1px solid var(--color-mist);background:var(--color-surface)}.item-row__subtotal{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-graphite);padding:0 var(--space-1)}.form-total{display:flex;justify-content:flex-end;align-items:baseline;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-ink);padding-top:var(--space-3);border-top:1px solid var(--color-mist);margin-top:var(--space-2)}.form-total span{font-size:var(--text-xs);font-family:var(--font-body);color:var(--color-graphite);text-transform:uppercase}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3) var(--space-5);margin-bottom:var(--space-5);font-size:var(--text-sm)}.detail-grid dt{color:var(--color-graphite);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em}.detail-grid dd{margin:var(--space-1) 0 0;font-weight:600;color:var(--color-ink)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 var(--space-3)}.field-row{display:flex;gap:var(--space-3)}.field-row .field{flex:1}.muted{color:var(--color-graphite);font-size:var(--text-sm)}.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-4)}.report-card{background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-md);padding:var(--space-5)}.report-card h3{font-size:var(--text-md);margin-bottom:var(--space-1)}.report-card p{font-size:var(--text-sm);color:var(--color-graphite);margin:0 0 var(--space-4)}.report-card__actions{display:flex;gap:var(--space-2)}.toast-stack{position:fixed;top:var(--space-5);right:var(--space-5);z-index:1000;display:flex;flex-direction:column;gap:var(--space-2);max-width:360px}.toast{background:var(--color-ink);color:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-amber);animation:toast-in var(--speed-base) var(--ease)}.toast--success{border-left-color:var(--color-moss)}.toast--error{border-left-color:var(--color-rust)}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.combobox{position:relative}.combobox__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:280px;overflow-y:auto;z-index:30}.combobox__status{padding:var(--space-3);font-size:var(--text-sm);color:var(--color-graphite);text-align:center}.combobox__option{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--color-mist)}.combobox__option:last-child{border-bottom:none}.combobox__option:hover,.combobox__option--active{background:#c9a2271a}.combobox__option-main{display:flex;flex-direction:column;min-width:0}.combobox__sku{font-size:var(--text-xs);color:var(--color-graphite)}.combobox__name{font-size:var(--text-sm);color:var(--color-ink);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.combobox__option-meta{display:flex;flex-direction:column;align-items:flex-end;font-size:var(--text-xs);color:var(--color-graphite);flex-shrink:0}.combobox__stock--empty{color:var(--color-rust);font-weight:600}.movement-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);max-height:60vh;overflow-y:auto}.movement-list li{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-mist)}.movement-list li:last-child{border-bottom:none}.movement-list__info{display:flex;flex-direction:column}.movement-list__info strong{font-size:var(--text-sm)}.movement-list__info span{font-size:var(--text-xs);color:var(--color-graphite)}.alert-banner{display:flex;align-items:center;justify-content:space-between;background:#c1442d14;border:1px solid rgba(193,68,45,.25);color:var(--color-rust);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-4)}.role-permissions{display:flex;flex-direction:column;gap:var(--space-4)}.role-permissions__card{background:var(--color-surface);border:1px solid var(--color-mist);border-radius:var(--radius-md);padding:var(--space-5)}.role-permissions__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.role-permissions__header h3{font-size:var(--text-md)}.role-permissions__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-2) var(--space-4)}.role-permissions__item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-graphite)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}ul,ol{margin:0;padding:0}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}table{border-collapse:collapse;width:100%}:focus-visible{outline:2px solid var(--color-amber);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}:root{--color-ink: #161512;--color-ink-soft: #272319;--color-paper: #f7f2e4;--color-surface: #ffffff;--color-amber: #c9a227;--color-amber-dark: #a3811e;--color-rust: #a23b2b;--color-moss: #3b6b45;--color-graphite: #4a463c;--color-mist: #e2dcc8;--color-line: #2a261c;--color-bg: var(--color-paper);--color-surface-1: var(--color-surface);--color-text: var(--color-ink);--color-text-muted: var(--color-graphite);--color-border: var(--color-mist);--color-primary: var(--color-amber);--color-primary-strong: var(--color-amber-dark);--color-danger: var(--color-rust);--color-success: var(--color-moss);--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1.0625rem;--text-lg: 1.375rem;--text-xl: 1.75rem;--text-2xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 18px;--shadow-sm: 0 1px 2px rgba(22, 21, 18, .07);--shadow-md: 0 6px 20px rgba(22, 21, 18, .1);--shadow-lg: 0 16px 40px rgba(22, 21, 18, .18);--sidebar-width: 248px;--topbar-height: 64px;--ease: cubic-bezier(.4, 0, .2, 1);--speed-fast: .12s;--speed-base: .2s}html{font-family:var(--font-body);font-size:16px;background:var(--color-bg);color:var(--color-text)}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;background:var(--color-bg);color:var(--color-text)}h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-ink);margin:0;letter-spacing:-.01em}code,.mono{font-family:var(--font-mono)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-mist);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#d4d0c4}.app-shell{display:flex;min-height:100vh;background:var(--color-bg)}.app-main{flex:1;margin-left:var(--sidebar-width);min-width:0;display:flex;flex-direction:column}.app-content{padding:var(--space-6);flex:1}@media (max-width: 960px){.app-main{margin-left:0}}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
