.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-bg-dark);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar-brand{padding:28px 24px 24px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-brand-name{font-family:var(--font-heading);font-size:1.6rem;font-weight:600;letter-spacing:.3em;color:#fff;line-height:1}.sidebar-brand-sub{font-family:var(--font-heading);font-size:.62rem;letter-spacing:.18em;color:var(--color-primary);margin-top:5px;text-transform:uppercase}.sidebar-nav{flex:1;padding:20px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-section-label{font-size:.62rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#ffffff4d;padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);color:#ffffff8c;font-size:.875rem;font-weight:400;transition:all .18s ease;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:#b8972f26;color:var(--color-primary-light)}.nav-item.active .nav-icon{color:var(--color-primary)}.nav-icon{font-size:1.1rem;flex-shrink:0;color:#fff6;transition:color .18s}.nav-item:hover .nav-icon{color:#ffffffb3}.sidebar-user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-username{font-size:.82rem;font-weight:500;color:#ffffffbf;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-role{font-size:.7rem;color:#ffffff4d;letter-spacing:.05em}.sidebar-avatar-clickable{cursor:pointer;transition:box-shadow .18s,transform .18s}.sidebar-avatar-clickable:hover{box-shadow:0 0 0 2px var(--color-primary);transform:scale(1.08)}.sidebar-role-admin{color:var(--color-primary)!important;font-weight:500;letter-spacing:.08em;text-transform:uppercase;font-size:.65rem}.sidebar-logout{background:transparent;border:none;color:#ffffff4d;cursor:pointer;padding:4px;border-radius:4px;font-size:1rem;transition:color .15s}.sidebar-logout:hover{color:var(--color-danger)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:99}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .27s cubic-bezier(.4,0,.2,1);z-index:200}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0000002e}}:root{--color-primary: #B8972F;--color-primary-light: #D4B94E;--color-primary-dark: #96791F;--color-accent: #8FA882;--color-accent-light: #C5D5BC;--color-bg-dark: #2C2C2C;--color-bg-main: #F8F6F1;--color-surface: #FFFFFF;--color-text: #3A3A3A;--color-text-light: #8B8B8B;--color-border: #E8E4DC;--color-success: #5A9E6F;--color-danger: #D45B5B;--color-warning: #E5A54B;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.1);--shadow-gold: 0 4px 20px rgba(184,151,47,.25);--font-heading: "Cormorant Garant", Georgia, serif;--font-body: "Inter", system-ui, sans-serif;--sidebar-width: 240px;--topbar-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background:var(--color-bg-main);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;background:var(--color-bg-main)}.page-body{padding:var(--space-xl)}h1,h2,h3,.heading{font-family:var(--font-heading);font-weight:600;color:var(--color-text);letter-spacing:.02em}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-lg);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;border:none;transition:all .2s ease}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-gold)}.btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-main);border-color:var(--color-primary-light)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.88}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-icon{padding:8px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-light);transition:all .15s}.btn-icon:hover{background:var(--color-bg-main);color:var(--color-primary)}.btn-icon.danger:hover{color:var(--color-danger)}.card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.badge-gold{background:#b8972f1f;color:var(--color-primary-dark)}.badge-sage{background:#8fa88226;color:#5a7a52}.badge-red{background:#d45b5b1f;color:var(--color-danger)}.badge-green{background:#5a9e6f1f;color:var(--color-success)}.badge-neutral{background:var(--color-bg-main);color:var(--color-text-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .35s ease forwards}.animate-slide-up{animation:slideUp .4s ease forwards}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.page-header h1{font-size:2rem;font-family:var(--font-heading)}.page-header p{color:var(--color-text-light);font-size:.875rem;margin-top:2px}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-lg) 0}.hamburger-btn{display:none;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text);font-size:1.5rem;padding:6px;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:background .15s}.hamburger-btn:hover{background:var(--color-bg-main)}@media (max-width: 768px){.hamburger-btn{display:flex}.main-content{margin-left:0}.page-body{padding:var(--space-md)}.page-header h1{font-size:1.4rem}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f6f1,#ede8df,#e8e0d0);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 40% at 20% 80%,rgba(143,168,130,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 80% 20%,rgba(184,151,47,.12) 0%,transparent 55%);pointer-events:none}.login-card{width:100%;max-width:420px;padding:48px 40px;background:#ffffffd1;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid rgba(184,151,47,.2);box-shadow:0 20px 60px #0000001a,0 4px 16px #b8972f1f;animation:slideUp .5s ease forwards;position:relative;z-index:1}.login-brand{text-align:center;margin-bottom:36px}.login-logo-text{font-family:var(--font-heading);font-size:3rem;font-weight:600;letter-spacing:.35em;color:var(--color-bg-dark);line-height:1}.login-logo-sub{font-family:var(--font-heading);font-size:.8rem;letter-spacing:.22em;color:var(--color-primary);margin-top:6px;text-transform:uppercase}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0 28px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,rgba(184,151,47,.35),transparent)}.login-divider span{font-size:.7rem;letter-spacing:.15em;color:var(--color-primary);text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{display:flex;flex-direction:column;gap:6px}.login-form label{font-size:.78rem;font-weight:500;letter-spacing:.05em;color:var(--color-text-light);text-transform:uppercase}.login-form input{padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:#ffffffb3;color:var(--color-text);transition:all .2s;outline:none}.login-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #b8972f1f;background:#fff}.login-submit{width:100%;padding:14px;margin-top:8px;background:var(--color-bg-dark);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .25s}.login-submit:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-gold)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-error{padding:10px 14px;background:#d45b5b14;border:1px solid rgba(212,91,91,.25);border-radius:var(--radius-sm);color:var(--color-danger);font-size:.85rem;text-align:center}.login-footer{text-align:center;margin-top:28px;font-family:var(--font-heading);font-style:italic;font-size:.85rem;color:var(--color-text-light)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.stats-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-lg) var(--space-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all .2s ease;animation:fadeIn .4s ease forwards}.stats-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stats-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:var(--space-md)}.stats-card-icon.gold{background:#b8972f1f;color:var(--color-primary)}.stats-card-icon.sage{background:#8fa88226;color:#5a7a52}.stats-card-icon.green{background:#5a9e6f1f;color:var(--color-success)}.stats-card-icon.red{background:#d45b5b1f;color:var(--color-danger)}.stats-card-icon.blue{background:#6382c81f;color:#6382c8}.stats-card-label{font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-light);margin-bottom:6px}.stats-card-value{font-family:var(--font-heading);font-size:1.35rem;font-weight:600;color:var(--color-text);line-height:1.1;white-space:nowrap}.stats-card-sub{font-size:.75rem;color:var(--color-text-light);margin-top:4px}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.chart-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.chart-card h3{font-size:1rem;font-family:var(--font-heading);margin-bottom:var(--space-lg);color:var(--color-text)}.chart-card-full{grid-column:1 / -1}.date-filter-bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap}.date-filter-bar label{font-size:.8rem;color:var(--color-text-light);font-weight:500}.date-filter-bar input[type=date],.date-filter-bar input[type=month]{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;background:var(--color-surface);color:var(--color-text);outline:none;transition:border-color .2s}.date-filter-bar input:focus{border-color:var(--color-primary)}.empty-chart{display:flex;flex-direction:column;align-items:center;justify-content:center;height:180px;color:var(--color-text-light);font-size:.85rem;gap:8px}.empty-chart-icon{font-size:2rem;opacity:.35}@media (max-width: 900px){.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.stats-card{padding:var(--space-md)}.stats-card-value{font-size:1.1rem}}.table-container{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);flex-wrap:wrap}.table-search{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-main);flex:1;min-width:200px;max-width:320px}.table-search input{border:none;background:transparent;outline:none;font-size:.875rem;color:var(--color-text);width:100%}.table-search-icon{color:var(--color-text-light);font-size:.9rem}.table-filter-select{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.875rem;color:var(--color-text);outline:none;cursor:pointer;transition:border-color .2s}.table-filter-select:focus{border-color:var(--color-primary)}.table-spacer{flex:1}table{width:100%;border-collapse:collapse}thead{background:var(--color-bg-main)}thead th{padding:10px 14px;text-align:left;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-light);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}thead th:hover{color:var(--color-text)}thead th.sorted{color:var(--color-primary)}thead th .sort-icon{display:inline-block;margin-left:4px;opacity:.5}thead th.sorted .sort-icon{opacity:1}tbody tr{border-top:1px solid var(--color-border);transition:background .12s}tbody tr:hover{background:#f8f6f199}tbody td{padding:11px 14px;font-size:.875rem;color:var(--color-text);vertical-align:middle}.td-muted{color:var(--color-text-light);font-size:.82rem}.table-actions{display:flex;gap:4px;align-items:center}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);font-size:.82rem;color:var(--color-text-light)}.pagination-controls{display:flex;gap:4px}.pagination-btn{width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.8rem;color:var(--color-text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.pagination-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.stock-ok{color:var(--color-success)}.stock-low{color:var(--color-warning)}.stock-out{color:var(--color-danger)}.table-empty{text-align:center;padding:48px var(--space-lg);color:var(--color-text-light)}.table-empty-icon{font-size:2.5rem;opacity:.3;margin-bottom:var(--space-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:fadeIn .2s ease forwards}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideUp .28s ease forwards}.modal-lg{max-width:720px}.modal-sm{max-width:400px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.4rem;font-family:var(--font-heading)}.modal-header p{font-size:.82rem;color:var(--color-text-light);margin-top:3px}.modal-close{background:transparent;border:none;color:var(--color-text-light);font-size:1.3rem;cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all .15s;margin-left:var(--space-md);flex-shrink:0}.modal-close:hover{background:var(--color-bg-main);color:var(--color-text)}.modal-body{padding:var(--space-xl)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--color-border)}.confirm-icon{width:56px;height:56px;border-radius:50%;background:#d45b5b1a;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-danger);margin:0 auto var(--space-md)}.confirm-dialog{text-align:center}.confirm-dialog h3{font-size:1.2rem;margin-bottom:8px}.confirm-dialog p{color:var(--color-text-light);font-size:.875rem}@media (max-width: 600px){.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh}.modal-body{padding:var(--space-md)}.modal-header{padding:var(--space-md) var(--space-md)}.modal-footer{padding:var(--space-md)}}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg) var(--space-md)}.form-grid .form-full{grid-column:1 / -1}@media (max-width: 600px){.form-grid{grid-template-columns:1fr}.form-grid .form-full{grid-column:1}}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--color-text-light);text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #b8972f1a}.form-group textarea{resize:vertical;min-height:80px}.form-group select{cursor:pointer}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-light);opacity:.7}.composition-section{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.composition-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--color-bg-main);border-bottom:1px solid var(--color-border)}.composition-header h4{font-family:var(--font-heading);font-size:.95rem;font-weight:600}.composition-list{padding:var(--space-md);display:flex;flex-direction:column;gap:8px}.composition-item{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;align-items:center;padding:8px 12px;background:var(--color-bg-main);border-radius:var(--radius-sm);font-size:.85rem}.composition-item-name{font-weight:500}.composition-item-qty{color:var(--color-text-light);font-size:.8rem}.composition-item-cost{color:var(--color-primary);font-weight:500;font-size:.8rem}.composition-add-row{display:grid;grid-template-columns:1fr 120px auto;gap:8px;align-items:flex-end;padding:var(--space-md);border-top:1px solid var(--color-border)}.composition-total{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-light)}.composition-total strong{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-primary)}.image-upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-xl);text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.image-upload-area:hover{border-color:var(--color-primary-light);background:#b8972f08}.image-upload-area input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.image-upload-icon{font-size:2rem;color:var(--color-primary);opacity:.5;margin-bottom:8px}.image-upload-text{font-size:.85rem;color:var(--color-text-light)}.image-preview{width:100%;height:160px;object-fit:cover;border-radius:var(--radius-sm)}.attachment-preview{display:flex;align-items:center;gap:var(--space-md);padding:12px 14px;background:var(--color-bg-main);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.attachment-icon{font-size:1.4rem;color:var(--color-primary)}.attachment-name{font-size:.875rem;font-weight:500;flex:1}.attachment-link{font-size:.8rem;color:var(--color-primary);text-decoration:underline;cursor:pointer}
