@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;700&display=swap";.login-page{position:relative;min-height:100vh;width:100%;background-color:var(--bg-color);color:var(--text-color);display:flex;justify-content:center;align-items:center;overflow:hidden;transition:background-color .3s ease}.login-card{background-color:var(--card-bg);padding:40px;border-radius:16px;box-shadow:0 10px 25px #0003;z-index:10;width:100%;max-width:400px;text-align:center;border:1px solid var(--border-color);transition:background-color .3s ease}.login-animation-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:1;pointer-events:none}.bubble{position:absolute;bottom:-100px;width:40px;height:40px;background-color:#00bfa526;border-radius:50%;opacity:0;animation:floatUp 10s infinite ease-in}.input-group label{font-size:.85rem;font-weight:600;color:var(--text-color);opacity:.8;margin-bottom:.5rem;margin-left:4px}.input-group input{width:100%;padding:14px 16px;background-color:#80808014;border:1px solid var(--border-color);border-radius:12px;color:var(--text-color);font-size:1rem;font-weight:500;transition:all .3s ease;box-shadow:inset 0 2px 4px #00000005}.input-group input:focus{outline:none;background-color:transparent;border-color:#00bfa5;box-shadow:0 0 0 4px #00bfa51a;transform:translateY(-1px)}.input-group svg{color:var(--text-color);opacity:.5;transition:color .3s}.input-group:focus-within svg{color:#00bfa5;opacity:1}@keyframes floatUp{0%{transform:translateY(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh);opacity:0}}.bubble:nth-child(1){left:10%;animation-duration:12s;width:20px;height:20px}.bubble:nth-child(2){left:20%;animation-duration:7s;animation-delay:1s;width:30px;height:30px}.bubble:nth-child(3){left:30%;animation-duration:10s;animation-delay:2s}.bubble:nth-child(4){left:40%;animation-duration:8s;animation-delay:0s;width:25px;height:25px}.bubble:nth-child(5){left:50%;animation-duration:11s;animation-delay:3s}.bubble:nth-child(6){left:60%;animation-duration:9s;animation-delay:1.5s;width:35px;height:35px}.bubble:nth-child(7){left:70%;animation-duration:13s;animation-delay:4s}.bubble:nth-child(8){left:80%;animation-duration:6s;animation-delay:2s;width:20px;height:20px}.bubble:nth-child(9){left:90%;animation-duration:10s;animation-delay:.5s;width:30px;height:30px}.bubble:nth-child(10){left:55%;animation-duration:14s;animation-delay:5s}.bubble:nth-child(11){left:25%;animation-duration:8s;animation-delay:3s;width:25px;height:25px}.bubble:nth-child(12){left:75%;animation-duration:11s;animation-delay:1s}.bubble:nth-child(13){left:15%;animation-duration:9s;animation-delay:2.5s;width:35px;height:35px}.bubble:nth-child(14){left:45%;animation-duration:13s;animation-delay:4s}.bubble:nth-child(15){left:85%;animation-duration:7s;animation-delay:2s}.stat-card{background-color:var(--card-bg);border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;box-shadow:0 4px 10px #00000026;transition:transform .2s ease,background-color .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-icon-container{width:50px;height:50px;border-radius:12px;display:flex;justify-content:center;align-items:center}.stat-info{display:flex;flex-direction:column}.stat-title{font-size:.9rem;color:var(--text-color);opacity:.7;margin:0}.stat-number{font-size:1.8rem;font-weight:700;color:var(--text-color);margin:5px 0 0}.stat-desc{font-size:.75rem;color:var(--text-color);opacity:.5}.dashboard{min-height:100vh;color:var(--text-color);background-color:var(--bg-color);transition:background-color .3s ease,color .3s ease}.dashboard-header{border-bottom:1px solid var(--border-color);padding-bottom:20px;margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.chart-box{background-color:var(--card-bg);border-radius:12px;padding:20px;box-shadow:0 4px 10px #00000026;transition:background-color .3s ease}.chart-box.pie-chart{grid-column:auto!important}.chart-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.chart-header h2{font-size:1.1rem;margin:0;color:var(--text-color)}@keyframes pulse-soft{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.pulse-icon{animation:pulse-soft 2s infinite ease-in-out}@keyframes bounce-small{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.bounce-icon{animation:bounce-small 2s infinite}.spin-hover{transition:transform .5s ease}.stat-card:hover .spin-hover{transform:rotate(360deg)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-slow{animation:spin 3s linear infinite}.reporte-carta{font-family:Arial,Helvetica,sans-serif;background:#fff;width:100%;max-width:216mm;min-height:255mm;margin:0 auto;color:#000;display:flex;flex-direction:column}.empresa-nombre-simple{font-size:11pt;font-weight:700;color:#222;margin-bottom:4px}.header-right{font-size:9pt;color:#4a4a4a;white-space:nowrap}.contenido-principal{flex-grow:1;padding:6mm}.detalle-titulo{font-size:10pt;font-weight:700}.detalle-id{font-size:7.5pt;background:#f0f0f0;padding:2px 8px;border-radius:10px;color:#555}.datos-formula{display:grid;grid-template-columns:repeat(3,1fr);gap:6mm;font-size:8pt;margin-bottom:8mm}.dato-label{display:block;font-size:7pt;color:#4c4c4c}.tabla-titulo{font-size:9pt;font-weight:700;margin-bottom:3mm}.observaciones-container{margin-top:8mm;border:.5px solid #ddd;min-height:22mm;padding:4px}.obs-header{font-size:7.5pt;font-weight:600;margin-bottom:4px}.obs-lines{display:flex;flex-direction:column;gap:6mm}.line{border-bottom:1px solid #ccc}.footer-fijo{background:#fff}.sistema-meta{text-align:center;font-size:6.5pt;color:#888;padding:4px 0;border-top:1px solid #eee}@media print{@page{size:letter;margin:5mm}body{margin:0;padding:0;background:#fff}.header-simple{position:fixed;top:0;left:0;right:0;height:24mm;background:#fff;z-index:100}.footer-fijo{position:fixed;bottom:0;left:0;right:0;height:20mm;background:#fff;z-index:100}.contenido-principal{margin-top:26mm;margin-bottom:22mm}.tabla-industrial thead{display:table-header-group}.tabla-industrial tr{page-break-inside:avoid}}.modal-content-large{background-color:var(--card-bg);color:var(--text-color);width:85%;max-width:1100px;height:85vh;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;padding:25px;animation:aparecerModal .25s ease-out;transition:background-color .3s ease,color .3s ease}.search-input{width:100%;padding:12px 12px 12px 45px;border:1px solid var(--border-color);background-color:var(--bg-color);color:var(--text-color);border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}.btn-details{background-color:#3572dc;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;display:inline-flex;transition:background .2s}.formula-page{box-sizing:border-box;display:flex;flex-direction:column;gap:1.5rem;background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s ease,color .3s ease}.action-bar{display:flex;justify-content:flex-end;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.formula-section{background-color:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000026;transition:background-color .3s ease,box-shadow .3s ease}.section-title svg,.subsection-title svg{color:inherit!important;fill:currentColor}.formula-section.locked{opacity:.4;pointer-events:none;filter:grayscale(80%)}.formula-section.locked .section-title:after{content:"(Bloqueado - Guarda el Paso 1)";font-size:.9rem;font-weight:400;color:#ed6c02;margin-left:1rem}.formula-section:not(.locked)+.formula-section.locked .section-title:after{content:"(Bloqueado - Agrega ingredientes)"}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.form-grid-ingredientes{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;align-items:flex-end}.input-group{display:flex;flex-direction:column}.input-group label{font-size:.9rem;color:var(--text-color);opacity:.7;margin-bottom:.5rem}.input-span-2{grid-column:span 3}.input-group input,.input-group select{width:100%;padding:12px;background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);font-size:1rem;box-sizing:border-box;transition:border-color .3s,box-shadow .3s,background-color .3s}.input-group input:focus,.input-group select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 5px #4caf5080}.input-group input:disabled{background-color:#80808033;color:var(--text-color);opacity:.5;cursor:not-allowed}.form-actions{grid-column:1 / -1;text-align:right;margin-top:1rem}.form-actions-ingredientes{white-space:nowrap}.form-actions-final{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:12px 20px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;color:#fff}.btn-default{background-color:#546e7a}.btn-default:hover:not(:disabled){background-color:#37474f;transform:scale(1.02)}.btn-danger:hover:not(:disabled){background-color:#c00404;transform:scale(1.02)}.btn-edit{background-color:#c14d2d}.btn-edit:hover:not(:disabled){background-color:#c14d2d;transform:scale(1.02)}.table-wrapper{overflow-x:auto}.ingredient-table{width:100%;border-collapse:collapse;margin-top:1rem}.ingredient-table thead{background-color:var(--bg-color)}.ingredient-table th,.ingredient-table td{padding:12px 15px;border-bottom:1px solid var(--border-color);text-align:left;color:var(--text-color)}.ingredient-table th{opacity:.8;font-size:.9rem;text-transform:uppercase}.ingredient-table .table-actions{display:flex;gap:1rem;text-align:center;width:60px}.btn-icon{background:none;border:none;padding:0;cursor:pointer;transition:transform .2s ease,filter .2s ease;display:flex;align-items:center;justify-content:center}.btn-icon .MuiSvgIcon-root{font-size:1.25rem}.btn-icon:hover{transform:scale(1.2);filter:brightness(1.2)}.btn-icon-edit{color:#ed6c02}.btn-icon-delete{color:#d32f2f}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-card{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.summary-label{font-size:.9rem;color:var(--text-color);opacity:.7}.summary-value{font-size:1.8rem;font-weight:700;color:var(--text-color)}.print-only-container{display:none}.pdf-hidden-container{position:absolute;left:-9999px;width:210mm;height:297mm;overflow:hidden;background-color:#fff;color:#000}.reporte-industrial{font-family:Arial,Helvetica,sans-serif;background:#fff;width:100%;max-width:216mm;min-height:255mm;margin:0 auto;color:#000;display:flex;flex-direction:column}.header-simple{display:flex;justify-content:space-between;align-items:flex-start;padding:6mm;border-bottom:1px solid #ddd}.header-left{display:flex;align-items:center;gap:10px}.logo-simple{width:47px;height:auto;object-fit:contain}.empresa-info{display:flex;flex-direction:column}.empresa-nombre-simple{font-size:11pt;font-weight:700;margin-bottom:2px}.empresa-rfc{font-size:8.5pt;color:#666}.header-right{font-size:8pt;color:#666;text-align:right;line-height:1.4}.seccion-cuerpo{flex-grow:1;padding:6mm}.detalle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4mm}.detalle-titulo{font-size:9pt;font-weight:700}.detalle-id{font-size:7.5pt;background:#f0f0f0;padding:2px 10px;border-radius:12px;color:#555}.info-grid-simple{display:grid;grid-template-columns:repeat(4,1fr);gap:6mm;font-size:8pt;margin-bottom:8mm}.dato-label{display:block;font-size:7pt;color:#666}.dato-valor{font-size:8.5pt;font-weight:600}.tabla-industrial{width:100%;border-collapse:collapse;font-size:8pt;border:.5px solid #ddd}.tabla-industrial th{background-color:#f6f6f6;border:.5px solid #ddd;padding:6px;font-weight:600;font-size:7.5pt}.tabla-industrial td{border:.5px solid #eee;padding:6px}.row-separator td{background:#333;color:#fff;font-weight:700}.text-center{text-align:center}.text-right{text-align:right}.bold{font-weight:700}.text-small{font-size:7.5pt}.mono{font-family:monospace}.padding-xl{padding:16px;font-style:italic;color:#666}.observaciones-box{margin-top:8mm;border:.5px solid #ddd;padding:4px;min-height:20mm}.box-title{font-size:7.5pt;font-weight:600;margin-bottom:4px}.box-content-lines .line{border-bottom:1px solid #ccc;height:5mm}.seccion-pie{background:#fff}.footer-meta{text-align:center;font-size:6.5pt;color:#888;border-top:1px solid #eee;padding-top:2px}@media print{@page{size:letter;margin:5mm}body{margin:0;padding:0}.header-simple{position:fixed;top:0;left:0;right:0;height:26mm;background:#fff;z-index:100}.seccion-pie{position:fixed;bottom:0;left:0;right:0;height:22mm;background:#fff;z-index:100}.seccion-cuerpo{margin-top:28mm;margin-bottom:24mm}.tabla-industrial thead{display:table-header-group}.tabla-industrial tr{page-break-inside:avoid}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content-large{background-color:var(--card-bg);color:var(--text-color);width:85%;max-width:1200px;height:85vh;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;padding:25px;animation:aparecerModal .25s ease-out;transition:background-color .3s ease,color .3s ease}@keyframes aparecerModal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid var(--border-color);padding-bottom:15px}.modal-header h2{margin:0;color:var(--text-color);font-size:1.5rem}.btn-close{background:transparent;border:none;cursor:pointer;color:var(--text-color);opacity:.6;padding:5px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-close:hover{background-color:#80808026;opacity:1;color:#d00}.search-bar-container{margin-bottom:20px}.input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-color);opacity:.5}.search-input{width:100%;padding:12px 12px 12px 45px;background-color:var(--bg-color);border:1px solid var(--border-color);color:var(--text-color);border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s,background-color .3s}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.table-container-scroll{flex:1;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px}.formulas-table{width:100%;border-collapse:collapse}.formulas-table th{background-color:var(--bg-color);padding:15px;text-align:left;position:sticky;top:0;z-index:1;font-weight:600;border-bottom:2px solid var(--border-color);color:var(--text-color)}.formulas-table td{padding:12px 15px;border-bottom:1px solid var(--border-color);color:var(--text-color);opacity:.9}.formulas-table tr:hover{background-color:#80808014}.btn-pdf{background-color:#dc3545;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;display:inline-flex;transition:background .2s}.btn-pdf:hover{background-color:#c82333}.btn-details{background-color:#3572dc;color:#fff;border:none;padding:3px 8px;border-radius:6px;cursor:pointer;display:inline-flex;transition:background .2s}.btn-details:hover{background-color:#1c5ce6}.actions-container{display:flex;align-items:center;justify-content:center;gap:10px}.produccion-page{display:flex;flex-direction:column;gap:1.5rem;background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s ease,color .3s ease}.produccion-card-step{background-color:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000026;transition:all .3s ease}.section-title,.subsection-title{display:flex;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:600;color:var(--text-color)!important;margin-top:0;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.section-title svg{color:inherit}.subsection-title{font-size:1.2rem;margin-top:2rem;margin-bottom:1rem;border:none;color:var(--text-color);opacity:.8}.divider{height:1px;background-color:var(--border-color);margin-top:2rem}.produccion-card-step.locked{opacity:.4;pointer-events:none;filter:grayscale(80%)}.produccion-card-step.locked .section-title:after{content:"(Bloqueado - Completa el Paso 1)";font-size:.9rem;font-weight:400;color:#ed6c02;margin-left:1rem}.produccion-card-step:not(.locked)+.produccion-card-step:not(.locked)+.produccion-card-step.locked .section-title:after{content:"(Bloqueado - Añade al menos una fórmula)"}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;align-items:flex-end}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.9rem;color:var(--text-color);opacity:.7;margin-bottom:.5rem}.form-input,.form-select{width:100%;padding:12px;background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);font-size:1rem;box-sizing:border-box;transition:border-color .3s,box-shadow .3s,background-color .3s}.form-input:focus,.form-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 5px #4caf5080}.form-input:disabled,.form-select:disabled{background-color:#80808033;color:var(--text-color);opacity:.5;cursor:not-allowed}.form-actions{width:100%}.production-final-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:12px 20px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;color:#fff;justify-content:center;height:47px;box-sizing:border-box}.btn:disabled{opacity:.5;cursor:not-allowed;background-color:#555}.btn-primary{background-color:#2e7d32}.btn-primary:hover:not(:disabled){background-color:#1b5e20;transform:scale(1.02)}.btn-warning{background-color:#ed6c02}.btn-warning:hover:not(:disabled){background-color:#e65100;transform:scale(1.02)}.btn-secondary{background-color:#546e7a}.btn-secondary:hover:not(:disabled){background-color:#37474f;transform:scale(1.02)}.btn-danger{background-color:#f84545}.btn-danger:hover:not(:disabled){background-color:#c31c1c;transform:scale(1.02)}.table-container{overflow-x:auto;width:100%}.table-container table{width:100%;border-collapse:collapse;margin-top:1rem}.table-container thead{background-color:var(--bg-color)}.table-container th,.table-container td{padding:12px 15px;border-bottom:1px solid var(--border-color);text-align:left;white-space:nowrap;color:var(--text-color)}.table-container th{color:var(--text-color);opacity:.8;font-size:.9rem;text-transform:uppercase}.table-container td:nth-child(2){white-space:normal;min-width:250px}.table-container td:nth-child(3){text-align:right;font-weight:600;white-space:nowrap}.col-acciones{display:flex;gap:1rem;justify-content:center;width:80px}.icon-btn{background:none;border:none;padding:0;cursor:pointer;transition:transform .2s ease,filter .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-color)}.icon-btn .MuiSvgIcon-root{font-size:1.25rem}.icon-btn:hover{transform:scale(1.2);filter:brightness(1.2)}.action-view{color:#2196f3}.action-delete{color:#d32f2f}.totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.total-box{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.total-box p{font-size:.9rem;color:var(--text-color);opacity:.7;margin:0}.total-value{font-size:1.8rem;font-weight:700;color:var(--text-color)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--card-bg);padding:2rem;border-radius:12px;box-shadow:0 5px 20px #0003;width:90%;max-width:800px;border:1px solid var(--border-color);z-index:1001;transition:background-color .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:1rem}.modal-header h4{margin:0;color:var(--text-color);font-size:1.4rem}.modal-close-btn{background:none;border:none;color:var(--text-color);opacity:.6;cursor:pointer;font-size:1.5rem;padding:0;display:flex}.modal-close-btn:hover{color:#f84545;opacity:1}.modal-subtitle{font-size:.9rem;color:var(--text-color);opacity:.7;margin-top:-.5rem;margin-bottom:1.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;font-family:Poppins,Roboto,sans-serif}html,body{overflow-x:hidden}
