.photo-upload{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.photo-upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.photo-upload-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.photo-count{font-size:.9rem;color:var(--text-secondary);background:var(--bg-primary);padding:.25rem .75rem;border-radius:12px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-bottom:1rem}.photo-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border-color);background:var(--bg-primary)}.photo-item img{width:100%;height:100%;object-fit:cover;display:block}.photo-remove-btn{position:absolute;top:.25rem;right:.25rem;width:28px;height:28px;border-radius:50%;border:none;background:#ef4444e6;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.photo-remove-btn:hover{background:#dc2626;transform:scale(1.1)}.photo-primary-badge{position:absolute;bottom:.5rem;left:.5rem;background:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.photo-upload-actions{display:flex;gap:.75rem;flex-wrap:wrap}.photo-action-btn{flex:1;min-width:100px;padding:.75rem 1rem;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;font-size:.95rem;cursor:pointer;transition:all .2s;font-weight:500}.photo-action-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px)}.photo-action-btn:disabled{opacity:.5;cursor:not-allowed}.photo-url-input{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.photo-url-input input{flex:1;min-width:200px;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;font-size:.95rem;background:var(--bg-primary);color:var(--text-primary)}.photo-url-input input:focus{outline:none;border-color:var(--primary-color)}.photo-url-add-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.photo-url-add-btn:hover{background:#0056b3;transform:translateY(-2px)}.photo-url-cancel-btn{padding:.75rem 1.5rem;background:transparent;color:var(--text-secondary);border:2px solid var(--border-color);border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.photo-url-cancel-btn:hover{background:var(--bg-secondary);border-color:var(--text-secondary)}.photo-uploading{display:flex;align-items:center;gap:.75rem;margin-top:1rem;padding:1rem;background:var(--bg-primary);border-radius:6px;color:var(--text-secondary)}.photo-upload-hint{margin-top:1rem;padding:.75rem;background:#fffbeb;border:1px solid #fbbf24;border-radius:6px;color:#92400e;font-size:.9rem;line-height:1.5}.spinner-small{width:20px;height:20px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.photo-upload-actions{flex-direction:column}.photo-action-btn{width:100%}.photo-url-input{flex-direction:column}.photo-url-input input{width:100%}}@media (prefers-color-scheme: dark){.photo-item{background:#2a2a2a}}.lotes-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999!important;padding:1rem;animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.lotes-modal{background:var(--bg-secondary);border-radius:16px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;z-index:10000;animation:slideUp .3s ease-out;box-shadow:0 10px 40px #00000080;padding:2rem}.lotes-summary{display:flex;gap:2rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;margin-bottom:1.5rem}.lotes-summary-item{display:flex;flex-direction:column;gap:.25rem}.lotes-summary-item .label{font-size:.875rem;color:var(--text-secondary)}.lotes-summary-item .value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.lote-form{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.lote-form h3{margin-top:0;margin-bottom:1rem;color:var(--text-primary)}.lote-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.lote-form .form-field{display:flex;flex-direction:column;gap:.5rem}.lote-form .form-field label{font-weight:500;font-size:.875rem;color:var(--text-primary)}.lote-form .form-field input,.lote-form .form-field textarea{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;background:var(--bg-secondary);color:var(--text-primary)}.lote-form .form-field input:focus,.lote-form .form-field textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.lote-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.lotes-list h3{margin-bottom:1rem;color:var(--text-primary)}.empty-message{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.lotes-table{overflow-x:auto}.lotes-table table{width:100%;border-collapse:collapse;background:var(--bg-secondary)}.lotes-table thead{background:var(--bg-tertiary)}.lotes-table th{padding:.75rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.lotes-table td{padding:.75rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.lotes-table tbody tr:hover{background:var(--bg-tertiary)}.lotes-table tbody tr.esgotado{opacity:.5;background:var(--bg-tertiary)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-success{background:#e8f5e9;color:#2e7d32}.badge-danger{background:#ffebee;color:#c62828}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.modal-header h2{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.modal-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}@media (max-width: 768px){.lotes-modal-overlay{padding:.5rem}.lotes-modal{max-width:100%;width:100%;margin:0;padding:1.5rem;max-height:95vh;border-radius:12px}.modal-header h2{font-size:1.25rem}.lotes-summary{flex-direction:column;gap:1rem}.lote-form{padding:1rem}.lote-form .form-row{grid-template-columns:1fr}.lotes-table{font-size:.75rem}.lotes-table th,.lotes-table td{padding:.5rem .25rem}.lote-form .form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%;justify-content:center}}.fab{position:fixed;right:var(--sp-16, 16px);bottom:80px;width:56px;height:56px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;box-shadow:var(--shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:var(--fw-600);line-height:1;z-index:1000;transition:transform .15s ease,background .15s ease,box-shadow .15s ease;padding:0}.fab:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.fab:active:not(:disabled){transform:translateY(0)}.fab:focus-visible{outline:3px solid var(--color-primary-soft);outline-offset:2px}.fab:disabled{background:var(--color-text-tertiary);cursor:not-allowed;box-shadow:var(--shadow-sm);opacity:.7}.fab-plus{display:block}@media (min-width: 1024px){.fab{bottom:112px;right:var(--sp-32, 32px)}}.venda-form-modal{max-width:560px;width:100%}.venda-form-step{font-size:.85em;color:#888;font-weight:400}.venda-form-body{display:flex;flex-direction:column;gap:16px}.venda-stepper{display:flex;gap:8px;align-items:center;justify-content:center;margin:4px 0 8px}.venda-stepper-dot{width:28px;height:28px;border-radius:50%;background:#e6e6ea;color:#555;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.venda-stepper-dot--active{background:var(--color-primary, #d6336c);color:#fff}.venda-stepper-dot--done{background:#c4e7d0;color:#1d6b3a}.venda-step{display:flex;flex-direction:column;gap:12px}.venda-step-title{margin:0 0 4px;font-size:1rem;font-weight:600}.venda-input{width:100%;padding:10px 12px;border:1px solid #d4d4d8;border-radius:8px;font-size:15px;box-sizing:border-box}.venda-input:focus{outline:2px solid var(--color-primary, #d6336c);outline-offset:-1px}.venda-input--inline{max-width:120px}.venda-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.venda-list-item{width:100%;text-align:left;background:#fafafa;border:1px solid #ececef;border-radius:8px;padding:10px 12px;font-size:14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:8px}.venda-list-item:hover:not(:disabled){background:#f3f3f5}.venda-list-item:disabled{opacity:.45;cursor:not-allowed}.venda-list-item-nome{font-weight:500}.venda-empty{padding:12px;text-align:center;color:#888;font-size:14px}.venda-muted{color:#888;font-size:13px}.venda-link-btn{background:none;border:none;color:var(--color-primary, #d6336c);font-size:14px;font-weight:500;cursor:pointer;padding:4px 0}.venda-link-btn:disabled{opacity:.5;cursor:not-allowed}.venda-add-btn{align-self:flex-start;padding:8px 0}.venda-cliente-pick{display:flex;justify-content:space-between;align-items:center;background:#f7f7fa;border-radius:8px;padding:12px}.venda-mini-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:#fafafa;border-radius:8px;border:1px dashed #d4d4d8}.venda-mini-form-actions{display:flex;gap:8px;justify-content:flex-end}.venda-checkbox{display:flex;align-items:center;gap:6px;font-size:14px}.venda-itens{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.venda-item{border:1px solid #ececef;border-radius:10px;padding:10px;background:#fff;display:flex;flex-direction:column;gap:6px}.venda-item-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.venda-item-nome{font-weight:500;font-size:14px}.venda-remove-btn{color:#b91c1c;font-size:13px}.venda-item-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.venda-qty-ctrl{display:inline-flex;align-items:center;border:1px solid #d4d4d8;border-radius:8px;overflow:hidden}.venda-qty-ctrl button{width:32px;height:32px;background:#fff;border:none;cursor:pointer;font-size:16px}.venda-qty-ctrl button:hover{background:#f3f3f5}.venda-qty-ctrl span{min-width:28px;text-align:center;font-weight:500}.venda-preco{display:inline-flex;align-items:center;gap:4px;border:1px solid #d4d4d8;border-radius:8px;padding:0 8px}.venda-preco span{color:#888;font-size:13px}.venda-preco input{border:none;outline:none;width:80px;padding:6px 0;font-size:14px;text-align:right}.venda-subtotal{font-weight:600;text-align:right}.venda-warn{color:#b91c1c;font-size:12px}.venda-item-foot{font-size:12px}.venda-produto-picker{display:flex;flex-direction:column;gap:8px;border:1px dashed #d4d4d8;border-radius:8px;padding:10px;background:#fafafa}.venda-totais{display:flex;flex-direction:column;gap:8px;border-top:1px solid #ececef;padding-top:12px}.venda-totais>div{display:flex;justify-content:space-between;align-items:center;font-size:14px}.venda-totais-final{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #ececef;padding-top:8px;font-size:16px}.venda-totais-final--lg{font-size:18px}.venda-totais-final strong{color:var(--color-primary, #d6336c)}.venda-chips{display:flex;flex-wrap:wrap;gap:8px}.venda-chips--sm .venda-chip{padding:4px 10px;font-size:13px}.venda-desconto-row{display:grid!important;grid-template-columns:auto auto 1fr;align-items:center;gap:8px}.venda-chip{background:#f3f3f5;border:1px solid #ececef;border-radius:999px;padding:8px 14px;font-size:14px;cursor:pointer}.venda-chip--active{background:var(--color-primary, #d6336c);color:#fff;border-color:var(--color-primary, #d6336c)}.venda-sub{display:flex;flex-direction:column;gap:8px;margin-top:4px;padding:10px;background:#fafafa;border-radius:8px}.venda-field{display:flex;flex-direction:column;gap:4px;font-size:14px}.venda-field select,.venda-field input{padding:8px;border:1px solid #d4d4d8;border-radius:6px;font-size:14px}.venda-parcelas-preview{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto}.venda-parcelas-preview li{display:grid;grid-template-columns:50px 1fr auto;gap:8px;font-size:13px;padding:6px 8px;background:#fff;border-radius:6px}.venda-resumo{display:flex;flex-direction:column;gap:12px}.venda-resumo-bloco{display:flex;flex-direction:column;gap:4px}.venda-resumo-bloco ul{margin:0;padding-left:20px;font-size:14px}.venda-form-footer{display:flex;justify-content:flex-end;gap:8px}.vendas-page{display:flex;flex-direction:column;gap:16px}.vendas-resumo{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;background:#fff;border:1px solid #ececef;border-radius:12px;padding:12px}.vendas-resumo-item{display:flex;flex-direction:column}.vendas-resumo-item span{font-size:12px;color:#888}.vendas-resumo-item strong{font-size:16px}.vendas-resumo-item--full{grid-column:1 / -1}.vendas-filters{display:flex;flex-wrap:wrap;gap:6px}.vendas-filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.vendas-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.venda-card{background:#fff;border:1px solid #ececef;border-radius:10px;padding:12px;display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer;gap:12px}.venda-card:hover{background:#fafafa}.venda-card-info{display:flex;flex-direction:column;gap:4px;min-width:0}.venda-card-cliente{font-weight:600;font-size:15px}.venda-card-meta{font-size:12px;color:#888}.venda-card-right{text-align:right;display:flex;flex-direction:column;gap:4px;align-items:flex-end}.venda-card-total{font-weight:600}.venda-status-chip{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:500}.venda-status-paga{background:#d1fae5;color:#065f46}.venda-status-areceber{background:#fef3c7;color:#92400e}.venda-status-areceber-atrasada{background:#fee2e2;color:#991b1b}.venda-status-cancelada{background:#e5e7eb;color:#4b5563}.venda-det-section{display:flex;flex-direction:column;gap:6px;padding-bottom:12px;border-bottom:1px solid #ececef}.venda-det-section:last-child{border-bottom:none}.venda-det-actions{display:flex;flex-wrap:wrap;gap:8px}.venda-det-actions button{flex:1 1 auto;min-width:140px}.venda-pagamentos{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;font-size:13px}.venda-pagamentos li{display:flex;justify-content:space-between;background:#fafafa;padding:6px 8px;border-radius:6px}[data-theme=dark] .venda-form-step,[data-theme=dark] .venda-muted,[data-theme=dark] .venda-empty,[data-theme=dark] .venda-card-meta,[data-theme=dark] .vendas-resumo-item span,[data-theme=dark] .venda-preco span{color:var(--text-secondary)}[data-theme=dark] .venda-input,[data-theme=dark] .venda-field select,[data-theme=dark] .venda-field input,[data-theme=dark] .venda-preco,[data-theme=dark] .venda-preco input{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .venda-input::placeholder,[data-theme=dark] .venda-field input::placeholder,[data-theme=dark] .venda-preco input::placeholder{color:var(--text-tertiary)}[data-theme=dark] .vendas-resumo,[data-theme=dark] .venda-card,[data-theme=dark] .venda-item,[data-theme=dark] .venda-list-item,[data-theme=dark] .venda-cliente-pick,[data-theme=dark] .venda-mini-form,[data-theme=dark] .venda-produto-picker,[data-theme=dark] .venda-sub,[data-theme=dark] .venda-parcelas-preview li,[data-theme=dark] .venda-pagamentos li{background:#2f2f33;border-color:#45454a;color:var(--text-primary)}[data-theme=dark] .vendas-resumo strong,[data-theme=dark] .venda-card-cliente,[data-theme=dark] .venda-card-total,[data-theme=dark] .venda-item-nome,[data-theme=dark] .venda-list-item-nome,[data-theme=dark] .venda-det-section strong,[data-theme=dark] .venda-subtotal{color:var(--text-primary)}[data-theme=dark] .venda-list-item:hover:not(:disabled),[data-theme=dark] .venda-card:hover,[data-theme=dark] .venda-qty-ctrl button:hover{background:#3a3a40}[data-theme=dark] .venda-chip{background:#303037;border-color:#474750;color:var(--text-primary)}[data-theme=dark] .venda-chip--active{background:var(--color-primary, #d6336c);border-color:var(--color-primary, #d6336c);color:#fff}[data-theme=dark] .venda-qty-ctrl{border-color:var(--border-color)}[data-theme=dark] .venda-qty-ctrl button{background:#35353a;color:var(--text-primary)}[data-theme=dark] .venda-totais,[data-theme=dark] .venda-totais-final,[data-theme=dark] .venda-det-section{border-color:#45454a}[data-theme=dark] .venda-status-paga{background:#32d74b29;color:#7ee68f}[data-theme=dark] .venda-status-areceber{background:#ff9f0a2e;color:#ffd18a}[data-theme=dark] .venda-status-areceber-atrasada{background:#ff453a2e;color:#ff9b96}[data-theme=dark] .venda-status-cancelada{background:#4b5563;color:#f3f4f6}:root{--color-primary: #C2185B;--color-primary-hover: #A31551;--color-primary-soft: #FCE4EC;--color-accent: #B8860B;--color-success: #2E7D32;--color-error: #C62828;--color-warning: #B8860B;--color-text: #1A1A1A;--color-text-secondary: #595959;--color-text-tertiary: #8A8A8A;--color-border: #E0E0E0;--color-bg-soft: #F5F5F5;--color-bg: #FFFFFF;--color-overlay: rgba(0, 0, 0, .55);--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--fs-12: .75rem;--fs-14: .875rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-22: 1.375rem;--fs-28: 1.75rem;--fw-400: 400;--fw-500: 500;--fw-600: 600;--fw-700: 700;--lh-tight: 1.2;--lh-base: 1.5;--sp-4: .25rem;--sp-8: .5rem;--sp-12: .75rem;--sp-16: 1rem;--sp-24: 1.5rem;--sp-32: 2rem;--sp-48: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06), 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--touch-target: 44px}html{font-family:var(--font-family-base)}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:.75rem;max-width:400px}.toast{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:space-between;gap:.75rem;animation:slideIn .3s ease-out;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.toast:hover{transform:translate(-4px);box-shadow:0 6px 16px #0003}.toast-content{display:flex;align-items:center;gap:.75rem;flex:1}.toast-icon{font-size:1.25rem;font-weight:700;flex-shrink:0}.toast-message{color:var(--text-primary);font-size:.9rem;line-height:1.4}.toast-close{background:none;border:none;color:var(--text-tertiary);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease,color .2s ease;flex-shrink:0}.toast-close:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.toast--success{border-left:4px solid var(--success-color)}.toast--success .toast-icon{color:var(--success-color)}.toast--error{border-left:4px solid var(--error-color)}.toast--error .toast-icon{color:var(--error-color)}.toast--warning{border-left:4px solid var(--warning-color)}.toast--warning .toast-icon{color:var(--warning-color)}.toast--info{border-left:4px solid var(--accent-color)}.toast--info .toast-icon{color:var(--accent-color)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.toast-container{top:12px;bottom:auto;right:10px;left:10px;max-width:none}.toast{padding:.875rem}.toast-message{font-size:.85rem}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}}.confirm-modal{position:relative;background:var(--bg-secondary);border-radius:12px;max-width:500px;width:90%;margin:2rem auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}.confirm-modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color)}.confirm-modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.confirm-modal-body{padding:1.5rem}.confirm-modal-message{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0}.confirm-modal-actions{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.confirm-modal-cancel-btn,.confirm-modal-confirm-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.confirm-modal-cancel-btn{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.confirm-modal-cancel-btn:hover{background:var(--bg-primary);border-color:var(--border-hover)}.confirm-modal-confirm-btn{background:var(--accent-color);color:#fff}.confirm-modal-confirm-btn:hover{background:color-mix(in srgb,var(--accent-color) 85%,black);transform:translateY(-1px)}.confirm-modal-delete-btn{background:var(--accent-color);padding:.75rem 1.5rem;border-radius:8px;color:#fff}.confirm-modal-delete-btn:hover{background:color-mix(in srgb,var(--accent-color) 85%,black);transform:translateY(-1px)}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.confirm-modal{width:95%;margin:1rem auto}.confirm-modal-actions{flex-direction:column-reverse}.confirm-modal-cancel-btn,.confirm-modal-confirm-btn{width:100%}}:root{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #fafafa;--text-primary: #1d1d1f;--text-secondary: #6e6e73;--text-tertiary: #86868b;--border-color: #d1d1d6;--border-hover: #b3b3b8;--accent-color: #e154e8;--error-bg: #fff5f5;--error-color: #ff3b30;--success-color: #34c759;--warning-color: #ff9500}[data-theme=dark]{--bg-primary: #242424;--bg-secondary: #2a2a2a;--bg-tertiary: #1d1d25;--text-primary: #f5f5f7;--text-secondary: #98989d;--text-tertiary: #636366;--border-color: #38383a;--border-hover: #48484a;--accent-color: #e154e8;--error-bg: #2c1517;--error-color: #ff453a;--success-color: #32d74b;--warning-color: #ff9f0a}*{margin:0;padding:0;box-sizing:border-box}html{font-size:14px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}#root{position:relative;z-index:1}#modal-root{position:relative;z-index:10000}.header{position:fixed;top:0;left:0;right:0;background:#ffffffd9;border-bottom:1px solid rgba(209,209,214,.6);z-index:1000;height:60px}[data-theme=dark] .header{background:#1c1c1ed9;border-bottom:1px solid rgba(56,56,58,.6)}.header-content{max-width:1400px;margin:0 auto;padding:0 1rem;height:100%;display:flex;align-items:center;justify-content:space-between}.header-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);letter-spacing:-.5px}.header-actions{display:flex;align-items:center;gap:1rem}.header-user{display:flex;align-items:center;gap:.75rem}.header-user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color)}.header-user-name{font-size:.875rem;font-weight:500;color:var(--text-secondary);display:none}.header-logout{font-size:.875rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:4px;padding:.5rem 1rem;cursor:pointer;transition:all .2s ease}.header-logout:hover{color:var(--error-color);border-color:var(--error-color)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(209,209,214,.6);border-radius:4px;background:#f5f5f780;cursor:pointer;transition:all .2s ease}.font-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(209,209,214,.6);border-radius:4px;background:#f5f5f780;cursor:pointer;transition:all .2s ease;margin-right:8px}[data-theme=dark] .theme-toggle,[data-theme=dark] .font-toggle{background:#2c2c2e80;border:1px solid rgba(56,56,58,.6)}.theme-toggle:hover,.font-toggle:hover{border-color:var(--border-hover);background:#f5f5f7b3}[data-theme=dark] .theme-toggle:hover,[data-theme=dark] .font-toggle:hover{background:#2c2c2eb3}.theme-icon,.font-icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center}.app-loading{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg-primary)}.app-loading p{font-size:.875rem;color:var(--text-secondary)}.app-container{min-height:100vh;display:flex;flex-direction:column;padding-top:60px}.app-content{flex:1;overflow-y:auto;padding-bottom:90px}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:#ffffffd9;border-top:1px solid rgba(209,209,214,.6);display:flex;justify-content:space-around;padding:.5rem 0;z-index:998}[data-theme=dark] .tab-bar{background:#1c1c1ed9;border-top:1px solid rgba(56,56,58,.6)}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;flex:1;border:none;background:none;cursor:pointer;padding:.5rem;color:var(--text-tertiary)}.tab-item--active{color:var(--accent-color)}.tab-icon{font-size:1.5rem;transition:transform .2s ease}.tab-item--active .tab-icon{transform:scale(1.1)}.tab-label{font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.page{max-width:1400px;margin:0 auto;padding:1rem;min-height:calc(100vh - 70px)}.page-header{margin-bottom:2rem;padding:1.5rem 0}.page-header h1{font-size:1.75rem;font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.page-subtitle{font-size:.875rem;color:var(--text-secondary)}.page-content{margin-top:2rem}.placeholder-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px}.placeholder-icon{font-size:4rem;margin-bottom:1rem}.placeholder-content h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.placeholder-content p{font-size:1rem;color:var(--text-secondary);max-width:400px}.dashboard{max-width:1400px;margin:0 auto;padding:1rem}.dashboard-header{margin-bottom:2rem;padding:1.5rem 0}.dashboard-greeting h1{font-size:1.75rem;font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.dashboard-month{font-size:.875rem;color:var(--text-secondary);text-transform:none}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1rem}.dashboard-message{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:2rem;text-align:center}.dashboard-message p{font-size:1rem;color:var(--text-secondary)}.dashboard-error{background:var(--error-bg);border:1px solid var(--error-color)}.dashboard-error p{color:var(--error-color)}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1.25rem}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.card-icon{font-size:1.5rem}.card-title{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.card-content{position:relative}.card-value{font-size:1.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.card-subtitle{font-size:.8125rem;color:var(--text-tertiary);margin-top:.25rem}.card-trend{position:absolute;top:0;right:0;font-size:1.25rem;font-weight:600}.card-trend--up{color:var(--success-color)}.card-trend--down{color:var(--error-color)}.card-trend--neutral{color:var(--warning-color)}@media (min-width: 640px){.dashboard{padding:1.5rem}.dashboard-greeting h1{font-size:2.25rem}.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.card{padding:1.5rem}.card-value{font-size:2.25rem}}@media (min-width: 1024px){.dashboard{padding:2rem}.dashboard-header{margin-bottom:2.5rem}.dashboard-greeting h1{font-size:2.5rem}.dashboard-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}.card{padding:2rem}.card-value{font-size:2.5rem}}@media (min-width: 1280px){.dashboard-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 640px){.tab-item{padding:.75rem 1rem}.tab-icon{font-size:1.75rem}.tab-label{font-size:.75rem}.page{padding:1.5rem}.page-header h1{font-size:2.25rem}.page-subtitle{font-size:1rem}}@media (min-width: 1024px){.app-container{padding-bottom:80px}.tab-bar{padding:.75rem 0}.tab-item{padding:1rem}.tab-label{font-size:.875rem}.page{padding:2rem}.page-header h1{font-size:2.5rem}.header-user-name{display:inline}.header-logout{padding:.5rem 1.25rem}}.login-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%);padding:1rem}.login-container{width:100%;max-width:420px;animation:fadeIn .5s ease-in-out}.login-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0000001a}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;font-weight:700;color:var(--accent-color);margin-bottom:.5rem}.login-header p{font-size:.875rem;color:var(--text-secondary);font-weight:500}.login-content{margin-bottom:2rem}.login-content h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.login-content>p{font-size:.875rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.login-error{display:flex;align-items:flex-start;gap:.75rem;background:var(--error-bg);border:1px solid var(--error-color);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.login-error span{font-size:1.25rem;flex-shrink:0}.login-error p{font-size:.875rem;color:var(--error-color);line-height:1.5;margin:0}.login-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.login-loading p{font-size:.875rem;color:var(--text-secondary)}.login-button-container{display:flex;justify-content:center;padding:1rem 0}.email-login-form{margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e154e81a}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:3rem}.toggle-password{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;opacity:.6;transition:opacity .2s ease}.toggle-password:hover{opacity:1}.password-hint{display:block;font-size:.75rem;color:var(--text-tertiary);margin-top:.5rem}.login-submit{width:100%;padding:.875rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;background:var(--accent-color);color:#fff;cursor:pointer;transition:all .2s ease}.login-submit:hover{background:#d144d8;transform:translateY(-1px);box-shadow:0 4px 12px #e154e84d}.login-submit:active{transform:translateY(0)}.login-mode-toggle{text-align:center;margin:1rem 0}.login-forgot{text-align:center;margin-top:.75rem}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-submit .spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem;vertical-align:middle}.login-mode-toggle p{font-size:.875rem;color:var(--text-secondary)}.link-button{background:none;border:none;color:var(--accent-color);font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:.875rem}.link-button:hover{color:#d144d8}.login-divider{position:relative;text-align:center;margin:1.5rem 0}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color)}.login-divider span{position:relative;display:inline-block;padding:0 1rem;background:var(--bg-secondary);color:var(--text-tertiary);font-size:.875rem;font-weight:500}.login-footer{text-align:center;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-footer p{font-size:.75rem;color:var(--text-tertiary);line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.login-card{padding:1.5rem}.login-header h1{font-size:1.75rem}.login-content h2{font-size:1.25rem}}.change-password-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%);padding:1rem}.change-password-container{width:100%;max-width:500px;animation:fadeIn .5s ease-in-out}.change-password-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0000001a}.change-password-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.warning-icon{font-size:3rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.change-password-header h1{font-size:1.5rem;font-weight:700;color:var(--error-color);margin-bottom:.5rem}.change-password-header p{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.user-info{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.user-info p{font-size:.875rem;color:var(--text-primary);margin:0}.user-info strong{color:var(--accent-color)}.change-password-error{display:flex;align-items:flex-start;gap:.75rem;background:var(--error-bg);border:1px solid var(--error-color);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.change-password-error span{font-size:1.25rem;flex-shrink:0}.change-password-error p{font-size:.875rem;color:var(--error-color);line-height:1.5;margin:0}.change-password-form{margin-bottom:1.5rem}.form-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.btn-secondary{width:100%;padding:.875rem;font-size:1rem;font-weight:600;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--bg-primary);border-color:var(--border-hover)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.security-tips{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.security-tips h3{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.security-tips ul{list-style:none;padding:0;margin:0}.security-tips li{font-size:.75rem;color:var(--text-secondary);padding:.25rem 0 .25rem 1.25rem;position:relative}.security-tips li:before{content:"✓";position:absolute;left:0;color:var(--success-color);font-weight:700}@media (max-width: 480px){.change-password-card{padding:1.5rem}.change-password-header h1{font-size:1.25rem}}.product-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .2s ease;animation:fadeIn .3s ease-in-out}.product-card:hover{border-color:var(--border-hover);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}[data-theme=dark] .product-card:hover{box-shadow:0 4px 12px #0000004d}.product-card-image{position:relative;height:160px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden}.product-card-image img{width:100%;height:100%;object-fit:cover}.product-card-image-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-tertiary);font-size:3rem;background:var(--bg-primary)}.product-card-inactive-badge{position:absolute;top:.5rem;right:.5rem;background:var(--error-color);color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:4px}.product-card-photo-count{position:absolute;bottom:.5rem;right:.5rem;background:#000000b3;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.product-card-content{padding:1rem}.product-card-header{margin-bottom:.75rem}.product-card-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem;line-height:1.3}.product-card-brand{font-size:.875rem;color:var(--text-secondary);font-weight:500}.product-card-description{font-size:.875rem;color:var(--text-secondary);line-height:1.4;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.product-card-price{display:flex;justify-content:space-between;align-items:center}.product-card-price-label{font-size:.875rem;color:var(--text-secondary)}.product-card-price-value{font-size:1rem;font-weight:600;color:var(--accent-color)}.product-card-stock{display:flex;justify-content:space-between;align-items:center}.product-card-stock-label{font-size:.875rem;color:var(--text-secondary)}.product-card-stock-value{font-size:.875rem;font-weight:500}.product-card-stock-status{font-size:.75rem;font-weight:500;text-align:center;padding:.25rem .5rem;border-radius:4px;background:rgba(var(--success-rgb),.1)}.product-card-category,.product-card-barcode{font-size:.75rem;color:var(--text-tertiary);display:flex;align-items:center;gap:.25rem}.product-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.product-card-action{flex:1;min-width:80px;min-height:var(--touch-target, 44px);padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.25rem}.product-card-action:hover{border-color:var(--border-hover);background:var(--bg-tertiary)}.product-card-action--primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.product-card-action--primary:hover{background:color-mix(in srgb,var(--accent-color) 85%,black);border-color:color-mix(in srgb,var(--accent-color) 85%,black)}.product-card-action--secondary{background:var(--bg-secondary);color:var(--text-primary)}.product-card-action--secondary:hover{background:var(--bg-tertiary);color:var(--accent-color)}.product-card-action--danger{color:var(--error-color);border-color:var(--error-color)}.product-card-action--danger:hover{background:var(--error-bg);border-color:var(--error-color)}.product-card-image-nav{position:absolute;top:50%;transform:translateY(-50%);background:#0009;color:#fff;border:none;padding:.5rem;cursor:pointer;z-index:2;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease,background .2s ease;font-size:1.25rem}.product-card:hover .product-card-image-nav{opacity:1}.product-card-image-nav:hover{background:#000c}.product-card-image-nav-prev{left:.5rem}.product-card-image-nav-next{right:.5rem}.product-card-image-indicators{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);display:flex;gap:.25rem;z-index:2}.product-card-image-indicator{width:6px;height:6px;border-radius:50%;background:#ffffff80;transition:all .2s ease}.product-card-image-indicator.active{background:#fff;width:20px;border-radius:3px}.products-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}@media (min-width: 640px){.products-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media (min-width: 1024px){.products-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}@media (min-width: 1280px){.products-grid{grid-template-columns:repeat(4,1fr)}}.products-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.products-search-wrapper{position:relative;flex:1;min-width:200px}.products-search{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;transition:all .2s ease}.products-search:not(:placeholder-shown){padding-right:2.5rem}.products-search:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}.products-search::placeholder{color:var(--text-tertiary)}.products-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .2s ease;opacity:.6}.products-search-clear:hover{opacity:1;color:var(--text-secondary)}.products-search-clear:active{transform:translateY(-50%) scale(.95)}.products-sort{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease;min-width:200px}.products-sort:hover{border-color:var(--border-hover)}.products-sort:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e154e81a}.products-add-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#e154e8,#b060b8);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e154e84d;white-space:nowrap}.products-add-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #e154e873;background:linear-gradient(135deg,#e154e8,#9a4da0)}.products-add-btn:active{transform:translateY(0);box-shadow:0 2px 10px #e154e84d}.products-add-btn svg{font-size:1.25rem}.products-filters{display:flex;gap:.5rem;flex-wrap:wrap}.products-filter{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s ease}.products-filter:hover,.products-filter--active{border-color:var(--accent-color);color:var(--accent-color);background:rgba(var(--accent-rgb),.1)}.products-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.products-empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.products-empty h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-primary)}.products-empty p{font-size:.875rem;margin-bottom:1.5rem}.products-loading{display:flex;justify-content:center;align-items:center;padding:3rem}.products-error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center}.products-error-icon{font-size:3rem;color:var(--error-color)}.products-error h3{color:var(--error-color);margin-bottom:.5rem}.products-error p{color:var(--text-secondary);margin-bottom:1rem}.products-retry-btn{padding:.75rem 1.5rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.products-retry-btn:hover{background:color-mix(in srgb,var(--accent-color) 85%,black)}.products-load-more{display:flex;justify-content:center;align-items:center;margin:2rem 0 1rem}.products-load-more-btn{padding:.875rem 2rem;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.products-load-more-btn:hover:not(:disabled){border-color:var(--accent-color);background:color-mix(in srgb,var(--accent-color) 5%,var(--bg-secondary));transform:translateY(-1px)}.products-load-more-btn:active:not(:disabled){transform:translateY(0)}.products-load-more-btn:disabled{opacity:.6;cursor:not-allowed}.spinner-small{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.product-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease-in-out}[data-theme=dark] .product-form-overlay{background:#000000bf}.product-form-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideInUp .3s ease-out;box-shadow:0 20px 60px #0000004d}.product-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 1.5rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.product-form-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.product-form-header h2:before{content:"📦";font-size:1.5rem}.product-form-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.product-form-close:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:rotate(90deg)}.gerenciar-container{padding:1.5rem;max-width:1200px;margin:0 auto}.gerenciar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.gerenciar-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.75rem;color:var(--text-primary);margin:0;font-weight:700}.gerenciar-header h2 svg{color:var(--accent-color);font-size:2rem}.gerenciar-header .btn-primary{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#e154e8,#b060b8);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e154e84d}.gerenciar-header .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px #e154e873;background:linear-gradient(135deg,#e154e8,#9a4da0)}.gerenciar-header .btn-primary:active{transform:translateY(0);box-shadow:0 2px 10px #e154e84d}.gerenciar-header .btn-primary svg{font-size:1.25rem}.create-user-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease-in-out}[data-theme=dark] .create-user-modal{background:#000000bf}.product-form-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideInUp .3s ease-out}.modal-content{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);animation:slideInUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 1.5rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.modal-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.modal-header h3:before{content:"👤";font-size:1.5rem}.btn-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.btn-close:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:rotate(90deg)}.product-form-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.product-form-close{width:32px;height:32px;border:none;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.125rem;transition:all .2s ease}.product-form-close:hover{background:var(--error-bg);color:var(--error-color)}.product-form{display:flex;flex-direction:column;flex:1;overflow:hidden}.product-form-content{flex:1;overflow-y:auto;padding:1.5rem}.form-field{margin-bottom:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr;gap:0}}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}.form-input--error{border-color:var(--error-color)}.form-input--error:focus{box-shadow:0 0 0 3px rgba(var(--error-rgb),.1)}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.form-input-group{display:flex;gap:.5rem}.form-input-group .form-input{flex:1}.form-button-secondary{padding:.875rem 1.5rem;border:2px solid var(--border-color);border-radius:10px;background:var(--bg-primary);color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.form-button-secondary:hover{border-color:var(--accent-color);background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px)}.form-error{display:block;font-size:.75rem;color:var(--error-color);margin-top:.25rem}.form-helper{display:block;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem;text-align:right}.form-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--success-bg);border:1px solid var(--success-color);border-radius:6px;margin-bottom:1.25rem}.form-info-label{font-size:.875rem;color:var(--success-color);font-weight:500}.form-info-value{font-size:.875rem;color:var(--success-color);font-weight:600}.form-image-preview{margin-top:.5rem;border:1px solid var(--border-color);border-radius:6px;overflow:hidden;max-width:200px}.form-image-preview img{width:100%;height:auto;display:block}.form-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;padding:.5rem 0}.form-checkbox{width:18px;height:18px;border:2px solid var(--border-color);border-radius:3px;background:var(--bg-primary)}.modal-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.btn-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:6px;transition:all .2s ease}.btn-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.create-user-form{padding:1.5rem}.password-generator-wrapper{display:flex;gap:.5rem;align-items:center}.password-generator-wrapper .password-display{flex:1;font-family:Courier New,monospace;letter-spacing:1px;font-weight:600;background:var(--bg-tertiary);cursor:default}.password-actions{display:flex;gap:.5rem}.btn-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:.75rem;border:2px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--bg-tertiary);border-color:var(--accent-color);transform:translateY(-2px)}.btn-icon:active{transform:translateY(0)}.password-hint{display:block;margin-top:.5rem;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input[type=email],.form-group input[type=text]{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:10px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:all .2s ease}.form-group input[type=email]:hover,.form-group input[type=text]:hover{border-color:#b060b8}.form-group input[type=email]:focus,.form-group input[type=text]:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 4px #e154e826;background:var(--bg-secondary)}.checkbox-group{background:var(--bg-tertiary);padding:1rem;border-radius:10px;border:2px solid transparent;transition:all .2s ease}.checkbox-group:hover{border-color:var(--border-color)}.checkbox-group label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:var(--text-primary)}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent-color)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.form-actions .btn-secondary{padding:.75rem 1.5rem;border-radius:10px;font-weight:500;transition:all .2s ease}.form-actions .btn-primary{padding:.75rem 2rem;border-radius:10px;font-weight:600;box-shadow:0 4px 12px #e154e84d;transition:all .2s ease}.form-actions .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e154e866}.form-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.delete-modal-body{padding:2rem 1.5rem;text-align:center}.delete-modal-icon{display:flex;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem}.delete-modal-text{font-size:1.125rem;color:var(--text-primary);margin-bottom:1rem;line-height:1.6}.delete-modal-text strong{color:#ef4444;font-weight:600}.delete-modal-warning{font-size:.9375rem;color:var(--text-secondary);margin-bottom:0;line-height:1.5}.btn-danger{background:transparent;color:#ef4444;border:1px solid #ef4444;padding:.75rem 2rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-danger:hover:not(:disabled){background:#ef44441a;border-color:#dc2626;color:#dc2626}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.users-list{background:var(--bg-secondary);border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #0000001a}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table tr:last-child td{border-bottom:none}.users-table tbody tr:hover{background:var(--bg-tertiary)}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{background:linear-gradient(135deg,#e154e8,#b060b8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.admin-badge{background:none;border:1px solid;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.form-checkbox:checked{background:var(--accent-color);border-color:var(--accent-color)}.form-checkbox:focus{outline:none;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}.product-form-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-color);background:var(--bg-primary)}.form-button-primary{padding:.875rem 2rem;background:linear-gradient(135deg,#e154e8,#b060b8);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;min-width:140px;justify-content:center;box-shadow:0 4px 12px #e154e84d}.form-button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e154e866;background:linear-gradient(135deg,#e154e8,#9a4da0)}.form-button-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #e154e84d}.form-button-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.spinner--small{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 640px){.product-form-overlay{padding:.5rem}.product-form-modal{max-height:95vh}.product-form-header,.product-form-content,.product-form-footer{padding:1rem}.form-input-group{flex-direction:column}.product-form-footer{flex-direction:column-reverse}.form-button-primary,.form-button-secondary{width:100%;justify-content:center}}.admin-badge.admin{border-color:var(--accent-color);color:var(--accent-color);background:#e154e81a}.admin-badge.admin:hover{background:#e154e833}.admin-badge.user{border-color:var(--text-secondary);color:var(--text-secondary)}.admin-badge.user:hover{border-color:var(--accent-color);color:var(--accent-color);background:#e154e81a}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}.status-badge.active{background:#34c7591a;color:var(--success-color)}.status-badge.inactive{background:#ff3b301a;color:var(--error-color)}.action-buttons{display:flex;gap:.5rem}.btn-icon{background:none;border:none;padding:.5rem;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;min-width:120px;justify-content:center}.form-button-primary:hover:not(:disabled){background:color-mix(in srgb,var(--accent-color) 85%,black);transform:translateY(-1px)}.form-button-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner--small{width:16px;height:16px;border-width:2px}@media (max-width: 640px){.product-form-overlay{padding:.5rem}.product-form-modal{max-height:95vh}.product-form-header,.product-form-content,.product-form-footer{padding:1rem}.form-input-group{flex-direction:column}.product-form-footer{flex-direction:column-reverse}.form-button-primary,.form-button-secondary{width:100%;justify-content:center}.btn-icon.btn-success{color:var(--success-color)}.btn-icon.btn-success:hover{background:#34c7591a}.btn-icon.btn-warning{color:var(--warning-color)}.btn-icon.btn-warning:hover{background:#ff95001a}.btn-icon.btn-danger{color:#ef4444}.btn-icon.btn-danger:hover{background:#ef44441a}.btn-icon.btn-info{color:#3b82f6}.btn-icon.btn-info:hover{background:#3b82f61a}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state svg{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{font-size:1.125rem}.error-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.error-state svg{font-size:4rem;margin-bottom:1rem;color:#ef4444}.error-state h3{font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.error-state p{font-size:1rem;margin-top:.5rem}@media (max-width: 768px){.gerenciar-container{padding:1rem}.gerenciar-header{flex-direction:column;align-items:stretch;text-align:center}.users-table{font-size:.875rem}.users-table th,.users-table td{padding:.75rem .5rem}.user-info{flex-direction:column;gap:.5rem;text-align:center}.action-buttons{justify-content:center}.form-actions{flex-direction:column}.modal-content{margin:1rem}}.product-detail-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999!important;padding:1rem;animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.product-detail-modal-content{background:var(--bg-secondary);border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;position:relative;z-index:10000;animation:slideUp .3s ease-out;box-shadow:0 10px 40px #00000080}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.product-detail-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;z-index:10;transition:all .2s ease}.product-detail-modal-close:hover{background:#000c;transform:scale(1.1)}.product-detail-modal-body{display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem}@media (max-width: 1024px){.product-detail-modal-body{grid-template-columns:1fr}}.product-detail-modal-images{position:relative;align-self:start}.product-detail-image-container{position:relative;width:100%;aspect-ratio:1;background:var(--bg-primary);border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.product-detail-image-container img{width:100%;height:100%;object-fit:contain}.product-detail-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-tertiary);gap:1rem}.product-detail-image-placeholder span{font-size:5rem}.product-detail-image-placeholder p{font-size:1.125rem}.product-detail-image-nav{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;border:none;padding:1rem;cursor:pointer;z-index:2;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:background .2s ease;font-size:1.5rem}.product-detail-image-nav:hover{background:#000000e6}.product-detail-image-nav-prev{left:1rem}.product-detail-image-nav-next{right:1rem}.product-detail-image-indicators{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.product-detail-image-indicator{width:10px;height:10px;border-radius:50%;background:var(--border-color);border:none;cursor:pointer;transition:all .2s ease;padding:0}.product-detail-image-indicator:hover{background:var(--border-hover);transform:scale(1.2)}.product-detail-image-indicator.active{background:var(--accent-color);width:32px;border-radius:5px}.product-detail-modal-info{display:flex;flex-direction:column;gap:1.5rem}.product-detail-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.product-detail-header h2{font-size:2rem;font-weight:600;color:var(--text-primary);margin:0}.product-detail-inactive-badge{background:var(--error-color);color:#fff;font-size:.875rem;font-weight:500;padding:.5rem 1rem;border-radius:6px;white-space:nowrap}.product-detail-field{display:flex;flex-direction:column;gap:.5rem}.product-detail-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.product-detail-value{font-size:1.125rem;color:var(--text-primary);font-weight:500}.product-detail-description{font-size:1rem;color:var(--text-primary);line-height:1.6;margin:0}.product-detail-price{font-size:1.75rem;font-weight:600;color:var(--accent-color)}.product-detail-stock{display:flex;align-items:center;gap:1rem}.product-detail-stock-value{font-size:1.125rem;color:var(--text-primary);font-weight:500}.product-detail-stock-status{font-size:.875rem;font-weight:500;padding:.25rem .75rem;border-radius:4px;background:rgba(var(--success-rgb, 52, 199, 89),.1)}.product-detail-barcode{font-family:Courier New,monospace;font-size:1.25rem;color:var(--text-primary);font-weight:600;letter-spacing:1px}.product-detail-dates{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.product-detail-date{display:flex;flex-direction:column;gap:.25rem}.product-detail-date .product-detail-label{font-size:.75rem}.product-detail-date .product-detail-value{font-size:.875rem;font-weight:400}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.product-detail-modal-body{grid-template-columns:1fr;gap:1.5rem;padding:1rem}.product-detail-modal-images{position:relative}.product-detail-header h2{font-size:1.5rem}.product-detail-image-nav{width:40px;height:40px;padding:.75rem}.product-detail-image-nav-prev{left:.5rem}.product-detail-image-nav-next{right:.5rem}.product-detail-dates{grid-template-columns:1fr}}}.users-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table{min-width:800px}@media (max-width: 1024px){.gerenciar-header{flex-direction:column;align-items:flex-start;gap:1rem}.gerenciar-header .btn-primary{width:100%;justify-content:center}}@media (max-width: 768px){.gerenciar-container{padding:1rem}.gerenciar-header h2{font-size:1.25rem}.users-table-wrapper{border-radius:12px;overflow:hidden}.users-table{min-width:100%;display:block}.users-table thead{display:none}.users-table tbody{display:block}.users-table tr{display:block;margin-bottom:1rem;border:1px solid var(--border-color);border-radius:12px;padding:1rem;background:var(--bg-secondary)}.users-table tr:last-child{margin-bottom:0}.users-table td{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border:none;text-align:right}.users-table td:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);text-align:left;flex-shrink:0;margin-right:1rem}.users-table td[data-label=Nome]{border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:.5rem}.users-table td[data-label=Nome]:before{display:none}.users-table td[data-label=Nome] .user-info{width:100%;justify-content:flex-start}.users-table td[data-label=Ações]{border-top:1px solid var(--border-color);padding-top:1rem;margin-top:.5rem}.users-table td[data-label=Ações]:before{display:none}.action-buttons{width:100%;justify-content:space-around!important}.action-buttons .btn-icon{flex:1;max-width:80px}.create-user-modal .modal-content{width:95%;max-width:500px;margin:1rem}.create-user-form .form-group{margin-bottom:1rem}.form-actions{flex-direction:column-reverse;gap:.75rem}.form-actions button{width:100%}}@media (max-width: 480px){.gerenciar-header h2{font-size:1.125rem}.users-table tr{padding:.75rem}.users-table td{padding:.5rem 0;font-size:.875rem}.user-avatar{width:28px;height:28px}.admin-badge,.status-badge{font-size:.75rem;padding:.25rem .5rem}.btn-icon{padding:.5rem}}.font-size-controls{position:fixed;top:65px;right:20px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:999;background:var(--bg-secondary);padding:8px 12px;border-radius:12px;box-shadow:0 4px 16px #00000026;border:1px solid var(--border-color)}.font-size-btn{width:36px;height:36px;border-radius:8px;border:none;background:var(--accent-color);color:#fff;font-size:20px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.font-size-btn:hover{transform:scale(1.05);filter:brightness(1.1)}.font-size-btn:active{transform:scale(.95)}.font-size-label{font-size:13px;font-weight:600;color:var(--text-primary);min-width:45px;text-align:center;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.font-size-controls{top:65px;right:15px;padding:6px 10px;gap:6px}.font-size-btn{width:32px;height:32px;font-size:18px}.font-size-label{font-size:12px;min-width:40px}}:root{--safe-area-inset-top: env(safe-area-inset-top, 0);--safe-area-inset-right: env(safe-area-inset-right, 0);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0);--safe-area-inset-left: env(safe-area-inset-left, 0)}@media (max-width: 768px){body{padding-top:var(--safe-area-inset-top);padding-bottom:var(--safe-area-inset-bottom);padding-left:var(--safe-area-inset-left);padding-right:var(--safe-area-inset-right)}button,a,input[type=button],input[type=submit],input[type=reset],.btn,.button{min-height:44px;min-width:44px;padding:12px 16px}.product-card,.user-card,.list-item{padding:16px;margin-bottom:12px}input,textarea,select{font-size:16px;min-height:44px;padding:12px;border-radius:8px}.container,.page-container{padding:16px}.flex-row{flex-direction:column;gap:12px}.modal button,.form-actions button{width:100%;margin-bottom:8px}h1{font-size:28px}h2{font-size:24px}h3{font-size:20px}.modal-content,.modal{max-width:100%;margin:0;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:90vh;overflow-y:auto}table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.navbar:not(.tab-bar){position:sticky;top:0;z-index:1000;padding:12px}.tab-bar{padding-bottom:calc(.5rem + var(--safe-area-inset-bottom))!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.tab-item{min-height:56px;padding:8px}button:active,.btn:active,a:active{transform:scale(.97);opacity:.8}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid #4F46E5;outline-offset:2px}.page-content{padding-top:8px;padding-bottom:calc(60px + var(--safe-area-inset-bottom))}button,.btn,a{-webkit-tap-highlight-color:rgba(0,0,0,.1);user-select:none;-webkit-user-select:none}html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}img{max-width:100%;height:auto}.card,.panel{border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px}ul,ol{padding-left:20px}li{margin-bottom:8px}}@media (max-width: 768px) and (orientation: landscape){.modal-content,.modal{max-height:85vh}}@media (max-width: 375px){.container,.page-container{padding:12px}h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}}@media (display-mode: standalone){body{padding-top:max(var(--safe-area-inset-top),12px)}.browser-only{display:none}.app-header{padding-top:var(--safe-area-inset-top)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease-in-out}[data-theme=dark] .modal-backdrop{background:#000000bf}.modal-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideInUp .3s ease-out;box-shadow:0 20px 60px #0000004d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.modal-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.form-button-primary,.form-button-secondary{padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;border:none}.form-button-primary{background:var(--accent-color);color:#fff}.form-button-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.form-button-primary:disabled{opacity:.6;cursor:not-allowed}.form-button-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.form-button-secondary:hover:not(:disabled){background:var(--bg-hover)}.form-button-secondary:disabled{opacity:.5;cursor:not-allowed}.form-content{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.form-group input,.form-group textarea{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;background:var(--bg-primary);color:var(--text-primary);transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.form-group fieldset{border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin:0}.form-group legend{font-size:.9375rem;font-weight:600;color:var(--text-primary);padding:0 .5rem}.product-card-badge--info{background-color:#dbeafe;color:#1e40af}[data-theme=dark] .product-card-badge--info{background-color:#1e3a8a;color:#93c5fd}.product-card-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-left:.25rem}.product-card-tag{background-color:var(--bg-tertiary);color:var(--text-secondary);padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;border:1px solid var(--border-color)}.product-card-observacoes{margin-top:.75rem;padding:.625rem;background-color:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:.8125rem;font-style:italic;border-left:3px solid var(--accent-color)}.tags-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem;margin-top:.5rem}.tag-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s}.tag-checkbox:hover{background-color:#f9fafb;border-color:#d1d5db}.tag-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.tag-checkbox input[type=checkbox]:checked+span{font-weight:600;color:#1e40af}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem 0}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-size:.9375rem;color:var(--text-primary, #1f2937)}.required{color:#dc2626;font-weight:600}.error-message{color:#dc2626;font-size:.75rem;margin-top:.25rem;display:block}.help-text{color:var(--text-tertiary, #9ca3af);font-size:.75rem;margin-top:.25rem;display:block}input.error,textarea.error{border-color:#dc2626;background-color:#fef2f2}input.error:focus,textarea.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-buttons button{padding:.5rem 1rem;border:1px solid #e5e7eb;background-color:#fff;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.filter-buttons button:hover{background-color:#f9fafb;border-color:#d1d5db}.filter-buttons button.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}@media (max-width: 768px){.tags-container{grid-template-columns:1fr}.cliente-card-actions{flex-direction:column}.filter-buttons{width:100%}.filter-buttons button{flex:1;min-width:0}}.clientes-table-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.clientes-table{width:100%;border-collapse:collapse;font-size:.9375rem}.clientes-table thead{background:var(--bg-tertiary);border-bottom:2px solid var(--border-color)}.clientes-table thead th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}.clientes-table thead th.clientes-table-center{text-align:center}.clientes-table thead th.clientes-table-actions{text-align:center;width:100px}.clientes-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .15s ease;cursor:pointer}.clientes-table tbody tr:hover{background:var(--bg-hover)}.clientes-table tbody tr:last-child{border-bottom:none}.clientes-table tbody td{padding:1rem;color:var(--text-primary);vertical-align:middle}.clientes-table-nome{font-weight:600;min-width:200px}.clientes-table-nome-container{display:flex;flex-direction:column;gap:.375rem}.clientes-table-nome-text{color:var(--text-primary);font-size:.9375rem}.clientes-table-observacoes{color:var(--text-tertiary);font-size:.8125rem;font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:300px}.clientes-table-telefone{font-family:Monaco,Courier New,monospace;color:var(--text-secondary);white-space:nowrap;min-width:140px}.clientes-table-email{color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clientes-table-marcas{min-width:150px}.clientes-table-marcas-tags{display:flex;flex-wrap:wrap;gap:.25rem}.clientes-table-marca-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;border:1px solid var(--border-color);white-space:nowrap}.clientes-table-center{text-align:center;white-space:nowrap}.clientes-table-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.clientes-table-badge--revendedor{background-color:#dbeafe;color:#1e40af}[data-theme=dark] .clientes-table-badge--revendedor{background-color:#1e3a8a;color:#93c5fd}.clientes-table-badge--cliente{background-color:var(--bg-tertiary);color:var(--text-tertiary);border:1px solid var(--border-color)}.clientes-table-empty{color:var(--text-tertiary);font-style:italic}.clientes-table-actions{text-align:center;white-space:nowrap}.clientes-table-actions button{display:inline-flex;align-items:center;justify-content:center}.clientes-table-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:6px;font-size:1.125rem;transition:all .2s;margin:0 .125rem}.clientes-table-btn--edit:hover{background:#3b82f61a}.clientes-table-btn--delete:hover{background:#ef44441a}@media (max-width: 1024px){.clientes-table-email{display:none}.clientes-table thead th:nth-child(3){display:none}}@media (max-width: 768px){.clientes-table-container{border-radius:8px}.clientes-table{font-size:.875rem}.clientes-table thead th{padding:.75rem .5rem;font-size:.75rem}.clientes-table tbody td{padding:.75rem .5rem}.clientes-table-nome{min-width:150px}.clientes-table-observacoes{max-width:200px;font-size:.75rem}.clientes-table-marcas{display:none}.clientes-table thead th:nth-child(4){display:none}.clientes-table-telefone{font-size:.8125rem;min-width:110px}.clientes-table-btn{padding:.375rem;font-size:1rem}}@media (max-width: 480px){.clientes-table-center{display:none}.clientes-table thead th:nth-child(5){display:none}.clientes-table thead th.clientes-table-actions{width:70px}.clientes-table-observacoes{display:none}}.clientes-cards{display:none;list-style:none;padding:0;margin:0;gap:var(--sp-12, 12px);flex-direction:column}@media (max-width: 768px){.clientes-cards{display:flex}.clientes-table-container{display:none}}.cliente-card{display:flex;align-items:stretch;background:var(--color-bg, #fff);border:1px solid var(--color-border, #E0E0E0);border-radius:var(--radius-md, 10px);box-shadow:var(--shadow-sm);overflow:hidden}.cliente-card-main{flex:1;display:flex;align-items:center;gap:var(--sp-12, 12px);padding:var(--sp-12, 12px);background:transparent;border:none;text-align:left;cursor:pointer;min-height:var(--touch-target, 44px);color:inherit}.cliente-card-avatar{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--color-primary, #C2185B);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--fs-18, 1.125rem);font-weight:var(--fw-700, 700);line-height:1}.cliente-card-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.cliente-card-nome{font-size:var(--fs-18, 1.125rem);font-weight:var(--fw-600, 600);color:var(--color-text, #1A1A1A);line-height:var(--lh-tight, 1.2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cliente-card-tel{font-size:var(--fs-14, .875rem);color:var(--color-text-secondary, #595959);text-decoration:none}.cliente-card-tel:hover{text-decoration:underline;color:var(--color-primary, #C2185B)}.cliente-card-pills{display:flex;flex-wrap:wrap;gap:var(--sp-4, 4px);margin-top:var(--sp-4, 4px)}.cliente-pill{display:inline-block;padding:2px 10px;border-radius:var(--radius-pill, 999px);font-size:var(--fs-12, .75rem);font-weight:var(--fw-500, 500);background:var(--color-bg-soft, #F5F5F5);color:var(--color-text-secondary, #595959);border:1px solid var(--color-border, #E0E0E0)}.cliente-pill--revendedor{background:var(--color-primary-soft, #FCE4EC);color:var(--color-primary, #C2185B);border-color:transparent}.cliente-card-actions{display:flex;flex-direction:column;border-left:1px solid var(--color-border, #E0E0E0)}.cliente-card-btn{min-width:var(--touch-target, 44px);min-height:var(--touch-target, 44px);background:transparent;border:none;cursor:pointer;font-size:1.1rem;padding:0 var(--sp-12, 12px);display:flex;align-items:center;justify-content:center;flex:1}.cliente-card-btn+.cliente-card-btn{border-top:1px solid var(--color-border, #E0E0E0)}.cliente-card-btn--edit:hover{background:var(--color-primary-soft, #FCE4EC)}.cliente-card-btn--delete:hover{background:#c6282814}.clientes-table-btn{min-width:var(--touch-target, 44px);min-height:var(--touch-target, 44px)}.products-add-btn--cta{background:var(--color-primary, #C2185B)!important;color:#fff!important;font-size:var(--fs-16, 1rem);font-weight:var(--fw-600, 600);padding:var(--sp-12, 12px) var(--sp-24, 24px);min-height:48px;border-radius:var(--radius-md, 10px);box-shadow:var(--shadow-sm)}.products-add-btn--cta:hover{background:var(--color-primary-hover, #A31551)!important}@media (max-width: 768px){.products-add-btn--toolbar{display:none!important}}.cliente-card-btn--whatsapp{color:#25d366;text-decoration:none}.cliente-card-btn--whatsapp:hover{background:#25d3661a}.clientes-page .products-toolbar{gap:12px}.clientes-page .products-search-wrapper{flex:1}.clientes-page .products-search.venda-input{padding-right:40px}[data-theme=dark] .clientes-page .products-search-wrapper{background:transparent}[data-theme=dark] .clientes-page .products-search{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .clientes-page .products-search::placeholder{color:var(--text-tertiary)}[data-theme=dark] .clientes-page .products-search-clear{color:var(--text-secondary)}[data-theme=dark] .clientes-table-container,[data-theme=dark] .cliente-card{background:#2f2f33;border-color:#45454a;color:var(--text-primary)}[data-theme=dark] .clientes-table thead{background:#303037;border-color:#45454a}[data-theme=dark] .clientes-table tbody tr:hover{background:#3a3a40}[data-theme=dark] .clientes-table thead th,[data-theme=dark] .clientes-table-observacoes,[data-theme=dark] .clientes-table-telefone,[data-theme=dark] .clientes-table-email,[data-theme=dark] .clientes-table-empty,[data-theme=dark] .cliente-card-tel,[data-theme=dark] .cliente-pill{color:var(--text-secondary)}[data-theme=dark] .clientes-table-marca-tag,[data-theme=dark] .cliente-pill{background:#303037;border-color:#474750}[data-theme=dark] .cliente-card-actions{border-left-color:#45454a}[data-theme=dark] .cliente-card-btn+.cliente-card-btn{border-top-color:#45454a}[data-theme=dark] .cliente-card-nome,[data-theme=dark] .clientes-table-nome-text{color:var(--text-primary)}[data-theme=dark] .clientes-table-btn--edit:hover{background:#3b82f62e}[data-theme=dark] .clientes-table-btn--delete:hover,[data-theme=dark] .cliente-card-btn--delete:hover{background:#ff453a2e}@media (max-width: 768px){.products-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.products-filters::-webkit-scrollbar{display:none}.products-filter{flex-shrink:0;white-space:nowrap}}.vendas-empty{text-align:center;padding:var(--sp-48, 48px) var(--sp-24, 24px);max-width:420px;margin:0 auto}.vendas-empty-icon{display:inline-block;font-size:64px;line-height:1;margin-bottom:var(--sp-16, 16px)}.vendas-empty h2{font-size:var(--fs-22, 1.375rem);font-weight:var(--fw-700, 700);color:var(--color-text, #1A1A1A);margin:0 0 var(--sp-8, 8px)}.vendas-empty p{font-size:var(--fs-16, 1rem);color:var(--color-text-secondary, #595959);line-height:var(--lh-base, 1.5);margin:0}
