:root{--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 40px;--sp-8: 48px;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 28px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--weight-normal: 400;--weight-medium: 500;--weight-semi: 600;--color-bg: #f5f5f7;--color-surface: #ffffff;--color-text: #1d1d1f;--color-secondary: #6e6e73;--color-tertiary: #aeaeb2;--color-border: rgba(0,0,0,.08);--color-border-hover: rgba(0,0,0,.14);--color-accent: #16a34a;--color-accent-hover: #15803d;--color-accent-muted: rgba(22, 163, 74, .08);--color-accent-pill: rgba(22, 163, 74, .12);--color-border-focus: rgba(22, 163, 74, .4);--color-success: #30d158;--color-warning: #ff9500;--color-danger: #ff3b30;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 100px;--shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.08);--shadow-lg: 0 8px 30px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;padding-bottom:env(safe-area-inset-bottom,20px)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-5);background:#ffffffb8;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.app-brand{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-lg);font-weight:var(--weight-semi);color:var(--color-accent);white-space:nowrap}.nav-logo{height:36px;width:auto;object-fit:contain}.app-brand span{font-weight:var(--weight-medium);color:var(--color-secondary);font-size:var(--text-base);margin-left:2px}.tab-nav{display:flex;gap:var(--sp-1);background:var(--color-bg);border-radius:var(--radius-pill);padding:3px}.tab{font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-medium);padding:6px 16px;border:none;border-radius:var(--radius-pill);background:transparent;color:var(--color-secondary);cursor:pointer;transition:all .2s;text-decoration:none}.tab.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.nav-user{display:flex;align-items:center;gap:var(--sp-2)}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-sm);color:var(--color-secondary);align-items:center;transition:background .15s}.hamburger-btn:hover{background:var(--color-bg)}.page{max-width:1100px;margin:0 auto;padding:var(--sp-5) var(--sp-4)}.page-narrow{max-width:600px;margin:0 auto;padding:var(--sp-5) var(--sp-4)}.content{min-height:calc(100vh - 120px)}.smart-input-bar{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-3) var(--sp-5);background:#ffffffb8;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);position:sticky;top:52px;z-index:99}.smart-input-label{font-size:var(--text-xs);font-weight:600;color:var(--color-accent);letter-spacing:.03em}.smart-input-row{display:flex;gap:var(--sp-2);align-items:center}.smart-input{flex:1;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);background:var(--color-surface);transition:border-color .2s}.smart-input:focus{outline:none;border-color:var(--color-border-focus)}.smart-hint{font-size:var(--text-xs);color:var(--color-secondary);margin:0}.smart-loading:after{content:"...";animation:dots 1.2s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-3)}.stat-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--shadow-sm);text-align:center}.stat-label{font-size:var(--text-xs);color:var(--color-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--sp-1)}.stat-value{font-size:var(--text-2xl);font-weight:var(--weight-semi)}.text-accent{color:var(--color-accent)!important}.text-success{color:var(--color-success)!important}.text-warning{color:var(--color-warning)!important}.text-danger{color:var(--color-danger)!important}.text-secondary{color:var(--color-secondary)}.text-tertiary{color:var(--color-tertiary)}.text-title{font-size:var(--text-xl);font-weight:var(--weight-semi)}.text-xs{font-size:var(--text-xs)}.toolbar{display:flex;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-4);flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:140px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-tertiary);pointer-events:none}.search-input{width:100%;padding:10px 12px 10px 36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);background:var(--color-surface);transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--color-border-focus)}.filter-select{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);background:var(--color-surface);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--color-border-focus)}.badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:var(--weight-medium);white-space:nowrap}.badge-neutral{background:#0000000f;color:var(--color-secondary)}.badge-success{background:#30d1581f;color:#248a3d}.badge-warning{background:#ff95001f;color:#c93400}.badge-danger{background:#ff3b301f;color:#d70015}.badge-purple{background:#8b5cf61f;color:#7c3aed}.badge-accent{background:var(--color-accent-pill);color:var(--color-accent)}.badge-entrada{background:#30d1581f;color:#248a3d}.badge-salida{background:#ff95001f;color:#c93400}.table-wrap{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}thead th{padding:var(--sp-3) var(--sp-4);font-size:var(--text-xs);font-weight:var(--weight-semi);text-transform:uppercase;letter-spacing:.5px;color:var(--color-secondary);text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}tbody td{padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--color-accent-muted)}.td-name{font-weight:var(--weight-medium);white-space:nowrap}.row-overdue{background:#ff95000f!important;border-left:3px solid var(--color-warning)}.row-overdue:hover{background:#ff95001a!important}.row-faded{opacity:.5}.row-faded:hover{opacity:.75}.row-actions{display:flex;gap:var(--sp-2);align-items:center}.action-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-sm);color:var(--color-secondary);transition:all .15s;display:flex;align-items:center}.action-btn:hover{background:var(--color-bg);color:var(--color-text)}.action-btn.wa{color:#25d366}.action-btn.wa:hover{background:#25d3661a}.action-btn svg{width:18px;height:18px}.action-btn{position:relative}.action-btn:after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:4px 10px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--weight-medium);background:var(--color-text);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:10}.action-btn:hover:after{opacity:1}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--sp-5);box-shadow:var(--shadow-sm)}.form-group{display:flex;flex-direction:column;gap:var(--sp-1)}.form-label{font-size:var(--text-xs);font-weight:var(--weight-semi);color:var(--color-secondary);text-transform:uppercase;letter-spacing:.5px}.form-control{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);background:var(--color-surface);transition:border-color .2s;width:100%}.form-control:focus{outline:none;border-color:var(--color-border-focus)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.flex{display:flex}.flex-col{flex-direction:column}.gap-4{gap:var(--sp-4)}.btn{font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-semi);padding:12px 24px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;text-align:center}.btn-primary{background:var(--color-accent);color:#fff;box-shadow:0 2px 8px #16a34a40}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 4px 16px #16a34a59}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--color-bg);color:var(--color-text)}.btn-secondary:hover{background:var(--color-border-hover)}.btn-danger{background:#ff3b301a;color:var(--color-danger)}.btn-danger:hover{background:#ff3b302e}.btn-sm{padding:8px 16px;font-size:var(--text-xs)}.w-full{width:100%}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--sp-4);animation:fadeIn .2s ease}.modal-box{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--sp-6);max-width:480px;width:100%;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-semi);margin-bottom:var(--sp-1)}.modal-subtitle{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:var(--sp-5)}.modal-body{display:flex;flex-direction:column;gap:var(--sp-4);margin-bottom:var(--sp-5)}.modal-footer{display:flex;gap:var(--sp-3);justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.toast{position:fixed;bottom:var(--sp-5);left:50%;transform:translate(-50%) translateY(20px);padding:var(--sp-3) var(--sp-5);border-radius:var(--radius-pill);font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-medium);color:#fff;box-shadow:var(--shadow-lg);z-index:300;opacity:0;transition:all .3s ease;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-success{background:var(--color-accent)}.toast-error{background:var(--color-danger)}.status-msg{padding:var(--sp-3);border-radius:var(--radius-sm);font-size:var(--text-sm);text-align:center}.status-msg.loading{color:var(--color-secondary)}.status-msg.success{color:var(--color-accent);background:var(--color-accent-muted)}.status-msg.error{color:var(--color-danger);background:#ff3b3014}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-8) var(--sp-4);color:var(--color-tertiary)}.empty-state p{font-size:var(--text-sm);margin-top:var(--sp-2)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--sp-4)}.login-card{text-align:center;max-width:360px;width:100%}.login-logo{height:64px;width:auto;margin-bottom:var(--sp-4)}.login-title{font-size:var(--text-2xl);font-weight:var(--weight-semi);color:var(--color-accent);margin-bottom:var(--sp-1)}.login-title span{font-weight:var(--weight-normal);color:var(--color-secondary)}.login-subtitle{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:var(--sp-5)}.login-footnote{font-size:var(--text-xs);color:var(--color-tertiary);margin-top:var(--sp-4)}.login-btn{width:100%;margin-top:var(--sp-2)}.stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-3)}.stock-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--shadow-sm)}.stock-card.low-stock{border-left:3px solid var(--color-warning)}.stock-card.expired{border-left:3px solid var(--color-danger)}.stock-card-img{width:100%;height:120px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:var(--sp-3)}.mov-cards{display:none}.mov-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--shadow-sm);margin-bottom:var(--sp-3)}.crm-cards{display:none}.crm-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--shadow-sm);margin-bottom:var(--sp-3)}.crm-card.row-overdue{border-left:3px solid var(--color-warning);background:#ff95000a}.crm-card.row-faded{opacity:.5}.crm-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--sp-2)}.crm-card-header strong{font-size:var(--text-base)}.crm-card-body{display:flex;flex-direction:column;gap:var(--sp-1);margin-bottom:var(--sp-3)}.crm-card-body .text-xs{line-height:1.4}.crm-card-actions{display:flex;gap:var(--sp-2);justify-content:flex-end;border-top:1px solid var(--color-border);padding-top:var(--sp-3)}.suggestions-bar{padding:var(--sp-3) var(--sp-5);background:linear-gradient(135deg,#16a34a0a,#3b82f60a);border-bottom:1px solid var(--color-border);animation:slideDown .3s ease}.suggestions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-2)}.suggestions-label{font-size:var(--text-xs);font-weight:600;color:var(--color-accent);letter-spacing:.03em}.suggestions-list{display:flex;flex-direction:column;gap:var(--sp-2)}.suggestion-item{display:flex;align-items:flex-start;gap:var(--sp-2);font-size:var(--text-sm);color:var(--color-text);padding:var(--sp-2) var(--sp-3);background:var(--color-surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);line-height:1.4}.suggestion-icon{flex-shrink:0;margin-top:1px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.agenda-group{margin-bottom:var(--sp-4)}.agenda-date-header{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 0;border-bottom:1px solid var(--color-border);margin-bottom:var(--sp-2)}.agenda-date-label{font-size:var(--text-sm);font-weight:var(--weight-semi);color:var(--color-text)}.agenda-date-label.today{color:var(--color-accent)}.agenda-date-label.overdue{color:var(--color-danger)}.agenda-date-count{font-size:var(--text-xs);color:var(--color-tertiary)}.agenda-events{display:flex;flex-direction:column;gap:var(--sp-2)}.agenda-event{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:background .15s}.agenda-event:hover{background:var(--color-accent-muted)}.agenda-event-seguimiento{border-left:3px solid #3b82f6}.agenda-event-visita{border-left:3px solid #7c3aed}.agenda-event-vencimiento{border-left:3px solid var(--color-danger)}.agenda-event-entrega{border-left:3px solid var(--color-success)}.agenda-event-content{flex:1;min-width:0}.agenda-event-content strong{font-size:var(--text-sm);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.stat-grid{grid-template-columns:repeat(2,1fr)}.stat-grid .stat-card:last-child{grid-column:span 2}.grid-2{grid-template-columns:1fr}.toolbar{flex-direction:column}.search-wrap{min-width:100%}.filter-select{width:100%}.page{padding:var(--sp-4) var(--sp-3)}.app-header{padding:var(--sp-3) var(--sp-3);position:sticky;top:0}.app-brand span{display:none}.stat-value{font-size:var(--text-xl)}.smart-input-bar,.suggestions-bar,.agenda-event{padding:var(--sp-3) var(--sp-3)}.hamburger-btn{display:flex}.tab-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);flex-direction:column;padding:var(--sp-2);gap:var(--sp-1);z-index:99;border-radius:0}.app-header.nav-open .tab-nav{display:flex}.tab-nav .tab{padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-sm);font-size:var(--text-sm);text-align:left}.table-wrap{display:none}.crm-cards,.mov-cards,.audit-cards{display:block}.action-btn:after{display:none}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr 1fr}.modal-box{padding:var(--sp-5)}}.audit-cards{display:none}.badge-info{background:#3b82f61f;color:#2563eb}.lote-toggle{background:none;border:none;cursor:pointer;font-size:var(--text-xs);color:var(--color-accent);font-weight:var(--weight-medium);padding:var(--sp-1) 0;display:inline-flex;align-items:center;gap:var(--sp-1)}.lote-toggle:before{content:"▸";display:inline-block;transition:transform .15s}.lote-toggle.open:before{transform:rotate(90deg)}.lote-list{margin-top:var(--sp-2);display:flex;flex-direction:column;gap:var(--sp-1)}.lote-item{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;font-size:var(--text-xs);padding:var(--sp-2);border-radius:6px;background:var(--color-bg)}.lote-item.lote-expiring{background:#ef444414;border-left:3px solid #ef4444}.lote-numero{font-weight:var(--weight-medium);color:var(--color-text)}.lote-qty,.lote-venc{color:var(--color-secondary)}.lote-ubic{color:var(--color-tertiary);font-style:italic}
