:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;background-color:#f5f7fa;opacity:0;animation:fadeInBody .2s ease-in-out forwards}@keyframes fadeInBody{to{opacity:1}}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;color:#213547;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}a:hover{color:#747bff}.spinner{display:inline-block;margin-left:8px;animation:spin 1s linear infinite}@keyframes pulse{0%{transform:scale(.9);opacity:.6}50%{transform:scale(1.2);opacity:.2}to{transform:scale(.9);opacity:.6}}.title-loader{display:inline-block;width:12px;height:12px;margin-left:8px;border-radius:50%;background-color:transparent}.title-loader.active{background-color:currentColor;animation:pulse 1s ease-in-out infinite}:root{--primary-blue: #0511F2;--dark-blue: #042959;--teal: #08A679;--green: #0BD979;--black: #0D0D0D;--white: #FFFFFF;--gray-light: #F5F7FA;--gray-medium: #E1E8ED;--gray-dark: #657786}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.landing-page{min-height:100vh;background:var(--white)}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-light)}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:20px}.spinner{width:48px;height:48px;border:4px solid var(--gray-medium);border-top-color:var(--primary-blue);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner p{color:var(--gray-dark);font-size:16px;font-weight:500}.hero{background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(11,217,121,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(8,166,121,.15) 0%,transparent 50%);pointer-events:none}.hero-container{max-width:800px;margin:0 auto;position:relative;z-index:1;width:100%}.logo-container{margin-bottom:40px;display:flex;justify-content:center}.hero-logo{width:180px;height:180px;object-fit:contain;background:var(--white);padding:28px;border-radius:50%;box-shadow:0 20px 60px #0000004d,0 0 0 8px #ffffff1a,0 0 0 16px #ffffff0d;transition:all .3s ease;animation:float 3s ease-in-out infinite}.hero-logo:hover{transform:scale(1.05);box-shadow:0 25px 70px #0006,0 0 0 8px #ffffff26,0 0 0 16px #ffffff14}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-title{font-size:48px;font-weight:700;color:var(--white);margin:0 0 20px;line-height:1.2;letter-spacing:-.5px}.hero-highlight{background:linear-gradient(135deg,var(--green) 0%,var(--teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;display:inline-block}.hero-description{font-size:20px;color:#ffffffe6;line-height:1.6;max-width:600px;margin:0 auto 32px}.hero-features-list{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:36px}.hero-feature-badge{display:flex;align-items:center;gap:8px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 16px;border-radius:50px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.hero-feature-badge:hover{background:#ffffff26;transform:translateY(-2px)}.hero-feature-badge svg{width:18px;height:18px;color:var(--green)}.hero-feature-badge span{font-size:14px;font-weight:500;color:var(--white)}.hero-pricing{margin-bottom:36px;padding:20px 32px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:2px solid rgba(255,255,255,.3);display:inline-block}.hero-trial-badge{font-size:15px;font-weight:600;color:var(--green);margin:0 0 8px;letter-spacing:.02em}.pricing-text{font-size:18px;font-weight:500;color:var(--white);margin:0}.pricing-amount{font-size:32px;font-weight:700;color:var(--green);text-shadow:0 2px 8px rgba(11,217,121,.5)}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:12px}.hero-cta-note{font-size:13px;color:#ffffffb3;margin:0;font-style:italic}.cta-button{display:inline-flex;align-items:center;gap:12px;padding:16px 32px;background:var(--white);color:var(--dark-blue);border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #0003}.cta-button:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0000004d}.cta-button:active{transform:translateY(0)}.cta-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.google-icon{width:24px;height:24px}.features{padding:100px 20px;background:var(--gray-light)}.features-container{max-width:1200px;margin:0 auto}.section-title{font-size:36px;font-weight:700;color:var(--black);text-align:center;margin:0 0 60px;letter-spacing:-.5px}.features-grid-main{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-bottom:40px}.feature-card{background:var(--white);padding:40px 32px;border-radius:16px;text-align:center;transition:all .3s ease;border:1px solid var(--gray-medium)}.feature-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px #0000001a;border-color:var(--teal)}.feature-icon-wrapper{width:72px;height:72px;margin:0 auto 24px;background:linear-gradient(135deg,var(--teal) 0%,var(--green) 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.feature-card:hover .feature-icon-wrapper{transform:scale(1.1)}.feature-icon{width:36px;height:36px;color:var(--white)}.feature-card h3{font-size:22px;font-weight:600;color:var(--black);margin:0 0 12px}.feature-card p{font-size:15px;color:var(--gray-dark);line-height:1.6;margin:0}.additional-features{padding:80px 20px;background:var(--white)}.additional-features-container{max-width:1200px;margin:0 auto}.features-grid-secondary{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;max-width:1200px;margin:0 auto}.feature-item-small:nth-child(-n+4){grid-column:span 3}.feature-item-small:nth-child(5),.feature-item-small:nth-child(6),.feature-item-small:nth-child(7){grid-column:span 4}.feature-item-small{display:flex;align-items:flex-start;gap:16px;padding:24px;background:var(--gray-light);border-radius:12px;transition:all .3s ease;border:1px solid transparent}.feature-item-small:hover{background:var(--white);border-color:var(--teal);box-shadow:0 8px 24px #00000014;transform:translateY(-4px)}.feature-item-small svg{width:32px;height:32px;color:var(--primary-blue);flex-shrink:0;transition:color .3s ease}.feature-item-small:hover svg{color:var(--teal)}.feature-item-small h4{font-size:16px;font-weight:600;color:var(--text-dark);margin:0 0 8px}.feature-item-small p{font-size:14px;color:var(--text-light);margin:0;line-height:1.5}.contact-section{background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);padding:80px 20px;position:relative;overflow:hidden}.contact-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(11,217,121,.1) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(8,166,121,.1) 0%,transparent 50%);pointer-events:none}.contact-container{max-width:1000px;margin:0 auto;position:relative;z-index:1}.contact-section .section-title{color:var(--white);text-align:center;margin-bottom:16px}.contact-description{text-align:center;font-size:18px;color:#ffffffe6;max-width:600px;margin:0 auto 48px}.contact-methods{display:flex;justify-content:center;max-width:500px;margin:0 auto}.contact-card{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:40px 32px;text-align:center;transition:all .3s ease}.contact-card:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-4px);box-shadow:0 12px 32px #0003}.contact-icon{width:64px;height:64px;margin:0 auto 24px;background:#0bd97933;border-radius:50%;display:flex;align-items:center;justify-content:center}.contact-icon svg{width:32px;height:32px;color:var(--green)}.contact-card h3{font-size:22px;font-weight:600;color:var(--white);margin:0 0 16px}.contact-link{display:inline-block;font-size:18px;font-weight:500;color:var(--green);text-decoration:none;margin-bottom:12px;transition:all .3s ease}.contact-link:hover{color:var(--teal);text-decoration:underline}.contact-note{font-size:14px;color:#ffffffb3;margin:0}.contact-text{font-size:16px;color:#fffc;margin:0 0 20px;line-height:1.6}.contact-links-group{display:flex;flex-direction:column;gap:12px}.contact-link-small{font-size:15px;color:var(--green);text-decoration:none;transition:all .3s ease;padding:8px 16px;background:#0bd9791a;border-radius:8px}.contact-link-small:hover{background:#0bd97933;color:var(--teal)}.footer{background:var(--dark-blue);padding:40px 20px;color:var(--white);text-align:center;border-top:1px solid rgba(255,255,255,.1)}.footer p{margin:0 0 16px;font-size:14px;opacity:.8}.footer-links{display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px}.footer-links a{color:var(--green);text-decoration:none;font-weight:500;transition:color .2s ease}.footer-links a:hover{color:var(--teal);text-decoration:underline}.footer-links span{opacity:.5}@media (max-width: 1024px){.features-grid-main{grid-template-columns:1fr;gap:24px}.features-grid-secondary{grid-template-columns:repeat(3,1fr);gap:20px}.feature-item-small:nth-child(5),.feature-item-small:nth-child(6),.feature-item-small:nth-child(7){grid-column:span 1;margin-left:0;margin-right:0}.feature-item-small{padding:28px 20px}}@media (max-width: 900px){.features-grid-secondary{grid-template-columns:repeat(2,1fr);gap:20px}}@media (max-width: 768px){.hero{padding:60px 20px 80px}.hero-logo{width:150px;height:150px;padding:25px}.hero-title{font-size:32px}.hero-description{font-size:18px}.hero-features-list{gap:12px}.hero-feature-badge{font-size:13px;padding:8px 14px}.hero-pricing{padding:16px 24px}.hero-trial-badge{font-size:14px}.pricing-text{font-size:16px}.pricing-amount{font-size:28px}.cta-button{padding:14px 28px;font-size:16px}.features-grid-secondary{grid-template-columns:1fr;gap:16px}.feature-item-small{padding:24px 20px;grid-column:auto!important}.feature-item-small:nth-child(n){grid-column:auto!important;margin-left:0!important;margin-right:0!important}}@media (max-width: 768px){.features,.additional-features{padding:60px 20px}.section-title{font-size:28px;margin-bottom:40px}.features-grid-main{grid-template-columns:1fr;gap:20px}.feature-card{padding:32px 24px}.contact-section{padding:60px 20px}.contact-card{padding:32px 24px}.footer{padding:32px 20px}}.features-grid-secondary{grid-template-columns:1fr;gap:16px}.feature-item-small{padding:20px}@media (max-width: 480px){.cta-button{width:100%;justify-content:center}.section-title{font-size:24px}.feature-card h3{font-size:20px}.feature-card p{font-size:14px}.features-grid-secondary{grid-template-columns:1fr}.feature-item-small:nth-child(5),.feature-item-small:nth-child(6),.feature-item-small:nth-child(7){grid-column:span 1;margin-left:0;margin-right:0}.feature-item-small{flex-direction:column;text-align:center}.feature-item-small svg{margin:0 auto}}.legal-page{min-height:100vh;background:#f5f7fa;padding:40px 20px}.legal-container{max-width:900px;margin:0 auto;background:#fff;padding:60px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.legal-container h1{font-size:36px;font-weight:700;color:#0d0d0d;margin:0 0 12px;line-height:1.2}.last-updated{font-size:14px;color:#657786;margin:0 0 40px;font-style:italic}.legal-container section{margin-bottom:40px}.legal-container h2{font-size:24px;font-weight:600;color:#042959;margin:0 0 16px;padding-top:20px;border-top:2px solid #E1E8ED}.legal-container section:first-of-type h2{border-top:none;padding-top:0}.legal-container h3{font-size:18px;font-weight:600;color:#0511f2;margin:20px 0 12px}.legal-container p{font-size:16px;line-height:1.8;color:#0d0d0d;margin:0 0 16px}.legal-container ul{margin:16px 0;padding-left:24px}.legal-container li{font-size:16px;line-height:1.8;color:#0d0d0d;margin-bottom:8px}.legal-container li strong{color:#042959;font-weight:600}.legal-footer{margin-top:60px;border-top:2px solid #E1E8ED;background:#f5f7fa;padding:30px;border-radius:8px}.legal-footer p{font-size:15px;color:#657786;margin:0;text-align:center;font-style:italic}@media (max-width: 768px){.legal-page{padding:20px 10px}.legal-container{padding:30px 20px}.legal-container h1{font-size:28px}.legal-container h2{font-size:20px}.legal-container h3{font-size:16px}.legal-container p,.legal-container li{font-size:15px}}@media (max-width: 480px){.legal-container{padding:20px 15px}.legal-container h1{font-size:24px}.legal-container h2{font-size:18px}}.plans-container{padding:2rem;max-width:1200px;margin:0 auto;background:#f5f5f5;min-height:100vh;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.plans-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.plans-header h1{margin:0;color:#111827;font-size:1.875rem;font-weight:700;display:flex;align-items:center;gap:.75rem}.plans-header h1:before{content:"";display:block;width:6px;height:32px;background:#2563eb;border-radius:4px}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#4b5563;font-weight:500;font-size:.95rem}.signout-btn{padding:.5rem 1rem;background:#fff;color:#ef4444;border:1px solid #fee2e2;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.signout-btn:hover{background:#fef2f2;border-color:#fca5a5;transform:translateY(-1px)}.plans-content{display:grid;gap:2rem}.subscription-status{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.subscription-status h2{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:700;border-bottom:2px solid #f3f4f6;padding-bottom:1rem}.status-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;border-radius:8px;border:1px solid #e5e7eb;background:#f9fafb;transition:all .2s ease}.status-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.status-card.active{background:#f0fdf4;border-left:4px solid #22c55e;border-color:#bbf7d0}.status-card.active .status-icon{color:#16a34a}.status-card.inactive{background:#fef2f2;border-left:4px solid #ef4444;border-color:#fecaca}.status-card.inactive .status-icon{color:#dc2626}.status-card.pending{background:#fffbeb;border-left:4px solid #f59e0b;border-color:#fde68a}.status-card.pending .status-icon{color:#d97706}.status-card.expired{background:#fff1f2;border-left:4px solid #f43f5e;border-color:#fecdd3}.status-card.expired .status-icon{color:#e11d48}.status-card.cancelled{background:#f3f4f6;border-left:4px solid #6b7280;border-color:#e5e7eb}.status-card.cancelled .status-icon{color:#4b5563}.status-icon svg{width:40px;height:40px}.status-info h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#1f2937}.status-info p{margin:.25rem 0;font-size:.95rem;color:#4b5563}.status-info .btn-primary{margin-top:1rem}.pending-notice{background:#fff7ed;border:1px solid #ffedd5;border-left:4px solid #f97316;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#9a3412;display:flex;align-items:center;gap:.75rem}.pending-notice p{margin:0 0 .5rem;font-weight:500}.pending-notice p:last-child{margin-bottom:0}.available-plans{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.available-plans h2{margin:0 0 2rem;color:#1f2937;font-size:1.5rem;font-weight:700;text-align:center}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.plan-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:2rem;text-align:center;transition:all .3s ease;position:relative;overflow:hidden;display:flex;flex-direction:column}.plan-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#bfdbfe}.plan-card:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:#2563eb}.plan-card h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:800}.plan-price{margin-bottom:2rem;padding:1.5rem;background:#f0f9ff;border-radius:12px;border:1px solid #dbeafe}.plan-price .price{display:block;font-size:2.5rem;font-weight:800;color:#2563eb;line-height:1}.plan-price .period{display:block;margin-top:.5rem;font-size:1.125rem;color:#6b7280;font-weight:500}.plan-features{list-style:none;padding:0;margin:0 0 2rem;text-align:left;flex:1}.plan-features li{color:#4b5563;font-weight:500;border-bottom:1px solid #f3f4f6;position:relative;padding:.75rem 0 .75rem 1.75rem}.plan-features li:last-child{border-bottom:none}.plan-features li:before{content:"✓";position:absolute;left:0;color:#22c55e;font-weight:700}.subscribe-btn{width:100%;padding:1rem;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #2563eb4d}.subscribe-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 8px -1px #2563eb66}.modal-overlay{position:fixed;inset:0;background:#111827b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal{background:#fff;border-radius:12px;padding:2rem;width:95%;max-width:500px;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:700;text-align:center}.subscription-modal .plan-summary{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:1.5rem;margin-bottom:2rem;text-align:center}.subscription-modal .plan-summary h4{margin:0 0 1rem;color:#0369a1;font-size:1.25rem}.subscription-modal .plan-description{margin:.5rem 0;color:#0c4a6e;font-size:1rem;font-weight:500}.pc-selector{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.pc-selector label{display:block;text-align:center;font-weight:600;color:#4b5563;margin-bottom:1rem}.quantity-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem}.quantity-btn{width:48px;height:48px;border:2px solid #e5e7eb;background:#fff;color:#2563eb;border-radius:8px;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.quantity-btn:hover:not(:disabled){border-color:#2563eb;background:#eff6ff;color:#1d4ed8}.quantity-btn:disabled{border-color:#f3f4f6;color:#d1d5db;cursor:not-allowed;background:#f9fafb}.quantity-display{font-size:1.5rem;font-weight:700;color:#1f2937;width:60px;text-align:center}.price-breakdown{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f3f4f6;color:#4b5563;font-size:.95rem}.price-row:last-child{border-bottom:none}.price-row.total{border-top:2px solid #e5e7eb;margin-top:.5rem;padding-top:1rem;font-weight:700;font-size:1.125rem;color:#1f2937}.price-row.total span:last-child{color:#2563eb;font-size:1.25rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-actions button{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;border:none}.modal-actions button:not(.primary){background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.modal-actions button:not(.primary):hover{background:#e5e7eb;color:#1f2937}.modal-actions button.primary{background:#2563eb;color:#fff}.modal-actions button.primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px -1px #2563eb4d}.sync-warning{color:#dc2626;font-size:.875rem;margin-top:.5rem;font-weight:500}.sync-btn,.renew-btn{margin-top:.5rem;width:100%;justify-content:center}.loading-spinner-circle{border:3px solid #f3f3f3;border-top:3px solid #2563eb;border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite}@media (max-width: 768px){.plans-container{padding:1rem}.plans-header{flex-direction:column;gap:1rem;text-align:center;padding:1rem}.plans-header h1{justify-content:center;font-size:1.5rem}.plans-header h1:before{display:none}.user-info{flex-direction:column;width:100%}.signout-btn{width:100%;min-height:44px}.subscription-status,.available-plans{padding:1.25rem}.status-card{flex-direction:column;text-align:center;padding:1.25rem}.status-card.active{border-left:1px solid #e5e7eb;border-top:4px solid #22c55e}.status-icon svg{width:36px;height:36px}.plans-grid{gap:1.25rem}.plan-card{padding:1.5rem}.plan-card .subscribe-btn{min-height:48px;padding:1rem}.modal{width:95%;margin:.75rem;padding:1.5rem}.modal-actions button{min-height:44px}.quantity-btn{min-width:44px;min-height:44px}}@media (max-width: 640px){.plans-container{padding:.75rem}.plans-header{padding:.75rem 1rem}.plans-header h1{font-size:1.35rem}.subscription-status,.available-plans{padding:1rem}.plan-price .price{font-size:2rem}}.payment-status-row{margin-top:10px!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important}.payment-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.payment-badge.paid{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.payment-badge.pending{background-color:#fef9c3;color:#854d0e;border:1px solid #fde047}.status-info p{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.quantity-counter{display:flex;align-items:center;gap:4px;background:#f8f9fa;border-radius:6px;padding:2px;border:1px solid #e9ecef;width:fit-content}.quantity-counter-btn{all:unset;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#495057;cursor:pointer;transition:all .15s ease;position:relative}.quantity-counter-btn:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd;color:#212529}.quantity-counter-btn:active:not(:disabled){transform:scale(.95)}.quantity-counter-btn:disabled{opacity:.4;cursor:not-allowed;background:#f8f9fa;color:#6c757d}.quantity-counter-btn:focus{outline:2px solid #007bff;outline-offset:1px}.quantity-counter-input{all:unset;width:40px;height:28px;text-align:center;background:transparent;color:#495057;font-size:14px;font-weight:500;border:none;outline:none}.quantity-counter-input:focus{background:#fff;border-radius:2px;outline:1px solid #007bff}.quantity-counter-input:disabled{opacity:.6;cursor:not-allowed}.quantity-counter-btn:before,.quantity-counter-btn:after,.quantity-counter-input:before,.quantity-counter-input:after{display:none!important;content:none!important}.quantity-counter-input::-webkit-outer-spin-button,.quantity-counter-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quantity-counter-input[type=number]{-moz-appearance:textfield}.products-screen{padding:24px 32px;background-color:#f8fafc;min-height:100vh;width:100%}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.products-header h1{font-size:1.8rem;font-weight:700;color:#1e293b;margin:0;letter-spacing:-.5px}.header-actions .btn{padding:10px 20px;font-weight:600;border-radius:8px;transition:all .2s}.products-toolbar{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;flex-wrap:wrap}.new-products-buttons{display:flex;gap:12px;flex-wrap:wrap}.new-products-buttons .btn{padding:10px 24px;border-radius:8px;font-weight:500;display:inline-flex;align-items:center;gap:8px;font-size:.9rem;min-width:unset;box-shadow:0 1px 2px #0000000d;transition:all .2s}.new-products-buttons .btn:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.search-container{position:relative;width:320px;flex-shrink:0}.search-container input{width:100%;padding:10px 40px 10px 42px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.9rem;transition:border-color .2s,box-shadow .2s;height:42px}.search-container input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-container .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8;width:18px;height:18px}.search-clear-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;transition:all .2s ease}.search-clear-btn:hover{background-color:#f1f5f9;color:#64748b}.search-clear-btn .icon{width:14px;height:14px}.products-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;border:1px solid #e2e8f0}.grid-table{display:table;width:100%;border-collapse:collapse}.grid-header{display:table-row;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.grid-header>div{display:table-cell;padding:16px 24px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#64748b;letter-spacing:.5px;vertical-align:middle}.table-body-skeleton,.table-body-content{display:table-row-group}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.grid-row{display:table-row;background-color:#fff;border-bottom:1px solid #f1f5f9;transition:background-color .15s ease}.grid-row:last-child{border-bottom:none}.grid-row:hover{background-color:#f8fafc}.grid-row>div{display:table-cell;padding:16px 24px;vertical-align:middle;color:#334155;font-size:.95rem}.grid-cell-type{width:10%}.grid-cell-name{width:35%}.grid-cell-price{width:15%;text-align:right;font-family:Inter,sans-serif;font-weight:500}.grid-cell-stock{width:15%;text-align:center}.grid-cell-unit{width:10%;text-align:center}.grid-cell-actions{width:15%;text-align:right}.product-type{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:9999px;font-size:.75rem;font-weight:600}.product-type.normal{background-color:#eff6ff;color:#3b82f6}.product-type.liquid{background-color:#ecfdf5;color:#10b981}.product-type.weight{background-color:#fffbeb;color:#f59e0b}.product-type.subproduct{background-color:#f5f3ff;color:#8b5cf6}.product-type .icon{width:14px;height:14px}.product-code{font-size:.8rem;color:#94a3b8;margin-top:4px}.parent-product{font-size:.8rem;color:#64748b;margin-top:2px;font-style:italic}.stock-info{display:flex;flex-direction:column;align-items:center}.stock-amount{font-weight:600}.stock-info.low-stock .stock-amount{color:#ef4444}.warning-icon{width:14px;height:14px;color:#ef4444;margin-top:2px}.actions{display:flex;justify-content:flex-end;gap:16px}.btn-action{background:none;border:none;font-size:.85rem;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:6px;transition:background-color .2s,color .2s}.btn-action.edit{color:#3b82f6;background-color:transparent}.btn-action.edit:hover{background-color:#eff6ff}.btn-action.barcode{color:#64748b;background-color:transparent}.btn-action.barcode:hover{background-color:#f1f5f9}.btn-action.delete{color:#ef4444;background-color:transparent}.btn-action.delete:hover{background-color:#fef2f2}.pagination-controls{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid #e2e8f0;background-color:#fff}.pagination-info{font-size:.9rem;color:#64748b}.pagination-buttons{display:flex;gap:8px}.btn-outline,.btn-page{border:1px solid #e2e8f0;background:#fff;color:#334155;padding:6px 12px;border-radius:6px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:4px}.btn-outline:hover:not(:disabled),.btn-page:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.btn-page.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.skeleton-row .skeleton{background-color:#e2e8f0;height:16px;border-radius:4px}.empty-state{text-align:center;padding:60px;color:#94a3b8}.empty-state .icon{width:48px;height:48px;margin-bottom:16px;opacity:.5}@media (max-width: 1024px){.products-toolbar{flex-direction:column;align-items:stretch}.search-container{width:100%}}@media (max-width: 768px){.products-screen{padding:16px}.grid-cell-type,.grid-cell-unit{display:none!important}.grid-cell-name{width:40%}.grid-cell-stock,.grid-cell-price,.grid-cell-actions{width:20%}.actions{flex-direction:column;gap:4px;align-items:flex-end}.btn-action{text-align:right;padding:4px 0}}.barcode-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.barcode-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.barcode-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.barcode-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#fff;padding:4px;border-radius:4px;transition:all .2s}.close-btn:hover{background-color:#fff3;color:#fff}.barcode-modal-content{padding:24px}.format-selector{margin-bottom:20px}.format-selector label{display:block;margin-bottom:8px;font-weight:600;color:#374151}.format-selector select{width:100%;padding:10px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;transition:border-color .2s}.format-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.barcode-preview{margin:24px 0;text-align:center}.barcode-display{background-color:#f9fafb;border-radius:8px;padding:20px;border:2px dashed #d1d5db}.barcode-display h3{margin:0 0 16px;color:#374151;font-size:1.2rem}.barcode-visual{display:flex;justify-content:center;align-items:center;background:#fff;padding:20px;border:2px solid #e5e7eb;border-radius:6px;margin:16px 0;min-height:120px}.barcode-visual svg{max-width:100%;height:auto}.barcode-text{font-family:Courier New,monospace;font-size:28px;font-weight:700;letter-spacing:3px;color:#000;background:#fff;padding:15px 20px;border:2px solid #000;border-radius:6px;margin:16px 0;display:inline-block;min-width:200px;text-align:center}.barcode-format{margin-top:12px;color:#6b7280;font-size:14px}.barcode-info{background-color:#f9fafb;padding:20px;border-radius:8px;border-left:4px solid #667eea;margin:24px 0}.barcode-info h4{margin:0 0 16px;color:#374151;font-size:1.1rem}.barcode-info ul{margin:0;padding-left:20px;list-style:none}.barcode-info li{margin:8px 0;color:#6b7280;line-height:1.5}.barcode-info strong{color:#111827}.barcode-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:24px 0}.btn{padding:12px 24px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;font-size:14px;min-width:120px}.btn-primary{background-color:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background-color:#5a67d8;transform:translateY(-1px)}.btn-secondary:hover:not(:disabled){background-color:#4b5563;transform:translateY(-1px)}.barcode-help{margin-top:30px;padding:20px;background-color:#f8fafc;border-radius:8px;border-left:4px solid #3b82f6}.barcode-help h3{margin:0 0 15px;color:#1f2937;font-size:16px}.barcode-help h4{margin:20px 0 10px;color:#374151;font-size:14px}.barcode-help ol,.barcode-help ul{margin:10px 0;padding-left:20px}.barcode-help li{margin:5px 0;color:#4b5563;font-size:13px;line-height:1.5}.barcode-help p{margin:10px 0;color:#4b5563;font-size:13px;line-height:1.5}.barcode-help strong{color:#1f2937}@media (max-width: 640px){.barcode-modal{width:95%;margin:20px}.barcode-modal-header{padding:16px 20px}.barcode-modal-content{padding:20px}.barcode-visual{padding:15px;min-height:100px}.barcode-text{font-size:20px;letter-spacing:2px;padding:12px 16px;min-width:150px}.barcode-actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:200px}.format-selector select{font-size:13px;padding:8px}.barcode-help{padding:15px}.barcode-help h3{font-size:14px}.barcode-help h4{font-size:13px}.barcode-help li,.barcode-help p{font-size:12px}}.product-modal{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.product-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0;flex-shrink:0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px 16px 0 0}.product-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.modal-close-btn{background:none;border:none;padding:8px;cursor:pointer;color:#64748b;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background-color:#f1f5f9;color:#334155}.modal-close-btn .icon{width:20px;height:20px}.product-modal-body{flex:1;overflow-y:auto;padding:24px;min-height:0}.product-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.9rem;font-weight:600;color:#334155}.form-group input,.form-group select{padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background-color:#f8fafc;cursor:not-allowed;color:#94a3b8}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.product-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0;border-radius:0 0 16px 16px}.product-modal-footer .btn{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:.95rem}.product-modal-footer .btn-secondary{background:#fff;color:#64748b;border:1px solid #e2e8f0}.product-modal-footer .btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.product-modal-footer .btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.product-modal-footer .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.product-modal-footer .btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.product-modal{width:95%;max-height:95vh}.form-row{grid-template-columns:1fr}.product-modal-header{padding:16px 20px}.product-modal-body{padding:20px}.product-modal-footer{padding:12px 20px}}.logs-screen{padding:20px;max-width:1200px;margin:0 auto}.screen-header h2{font-size:28px;font-weight:700;color:#1f2937;margin:0}.logs-stats{display:flex;align-items:center;gap:16px}.logs-count{background:#f3f4f6;color:#6b7280;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#64748b}.retry-btn{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:16px}.retry-btn:hover{background:#2563eb}.empty-state h3{font-size:20px;color:#6b7280;margin:0 0 8px}.empty-state p{color:#9ca3af;margin:0}.logs-table{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-header{display:grid;grid-template-columns:180px 120px 250px 1fr;gap:16px;padding:16px 20px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:14px;color:#374151;text-transform:uppercase;letter-spacing:.05em}.table-body{max-height:600px;overflow-y:auto}.table-row{display:grid;grid-template-columns:180px 120px 250px 1fr;gap:16px;padding:16px 20px;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.table-row:hover{background:#f9fafb}.col-date{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.col-action{display:flex;align-items:center}.action-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.action-create{background:#dcfce7;color:#166534}.action-update{background:#dbeafe;color:#1e40af}.action-delete{background:#fee2e2;color:#dc2626}.action-default{background:#f3f4f6;color:#6b7280}.col-entity{display:flex;flex-direction:column;gap:4px}.entity-info{display:flex;flex-direction:column;gap:6px}.entity-type{display:flex;align-items:center;gap:6px}.entity-type-text{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.entity-details{display:flex;flex-direction:column;gap:2px}.entity-name{font-weight:500;color:#1f2937;font-size:14px}.entity-extra{font-size:12px;color:#6b7280;font-family:Courier New,monospace}.entity-deleted{color:#9ca3af;font-style:italic;font-size:13px}.col-description{display:flex;flex-direction:column;gap:8px}.description-text{color:#374151;font-size:14px;line-height:1.4}.change-details{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border-radius:6px;font-size:12px;border-left:3px solid #e2e8f0}.old-value{color:#dc2626;font-weight:500;text-decoration:line-through}.arrow{color:#6b7280;font-weight:700}.new-value{color:#059669;font-weight:500}.load-more-section{display:flex;justify-content:center;padding:24px;background:#f9fafb;border-top:1px solid #e5e7eb}.load-more-btn{background:#6b7280;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.load-more-btn:hover:not(:disabled){background:#4b5563;transform:translateY(-1px)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.logs-screen{padding:16px}.screen-header{flex-direction:column;align-items:flex-start;gap:16px}.screen-header h2{font-size:24px}.table-header,.table-row{grid-template-columns:1fr;gap:8px}.table-header{display:none}.table-row{display:flex;flex-direction:column;padding:16px;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:8px;background:#fff}.col-date,.col-action,.col-entity,.col-description{width:100%}.col-date{order:1;justify-content:flex-end;font-size:12px}.col-action{order:2;margin-bottom:8px}.col-entity{order:3;margin-bottom:8px}.col-description{order:4}.change-details{flex-direction:column;align-items:flex-start;gap:4px}}@media (max-width: 480px){.logs-screen{padding:12px}.screen-header h2{font-size:20px}.table-row{padding:12px}.action-badge{padding:4px 8px;font-size:11px}.entity-name,.description-text{font-size:13px}}.header-actions{display:flex;align-items:center;gap:16px}.filter-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;cursor:pointer;transition:all .2s ease}.filter-toggle-btn:hover{background:#e5e7eb;border-color:#9ca3af}.filters-panel{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px;padding:16px}.filters-content{display:flex;align-items:end;gap:16px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:#374151}.date-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;color:#374151;min-width:150px}.date-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-actions{display:flex;gap:8px}.btn-apply-filter{padding:8px 16px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-apply-filter:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.btn-apply-filter:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-clear-filter{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-clear-filter:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.btn-clear-filter:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.header-actions{flex-direction:column;align-items:flex-start;gap:12px}.filters-content{flex-direction:column;align-items:stretch}.filter-actions{justify-content:stretch}.btn-apply-filter,.btn-clear-filter{flex:1}}.suppliers-screen{padding:20px;max-width:1200px;margin:0 auto}.add-supplier-btn{display:flex;align-items:center;gap:8px;background:#3b82f6;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.add-supplier-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.error-banner{display:flex;align-items:center;gap:12px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px}.close-error{margin-left:auto;background:none;border:none;color:#dc2626;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.suppliers-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.search-box{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.suppliers-count{color:#6b7280;font-size:14px;font-weight:500}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#64748b}.spinner{display:flex;gap:8px;align-items:center;margin-bottom:16px}.spinner:before,.spinner:after,.spinner{content:"";width:12px;height:12px;background:#667eea;border-radius:50%;animation:pulse-dots 1.4s ease-in-out infinite both}.spinner:before{animation-delay:-.32s}.spinner:after{animation-delay:-.16s}@keyframes pulse-dots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-state h3{margin:0 0 8px;color:#374151;font-size:20px;font-weight:600}.empty-state p{margin:0 0 24px;font-size:16px;line-height:1.5}.add-first-supplier-btn{display:inline-flex;align-items:center;gap:8px;background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.add-first-supplier-btn:hover{background:#2563eb;transform:translateY(-1px)}.suppliers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.supplier-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.supplier-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#d1d5db}.supplier-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.supplier-name{display:flex;align-items:center;gap:8px;flex:1}.supplier-name h3{margin:0;color:#1f2937;font-size:18px;font-weight:600;line-height:1.3}.supplier-actions{display:flex;gap:8px}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.edit-btn{background:#f3f4f6;color:#6b7280}.edit-btn:hover{background:#e5e7eb;color:#374151}.delete-btn{background:#fef2f2;color:#dc2626}.delete-btn:hover{background:#fee2e2;color:#b91c1c}.supplier-details{display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;align-items:flex-start;gap:8px;color:#6b7280;font-size:14px;line-height:1.4}.detail-item.notes{margin-top:4px;padding-top:8px;border-top:1px solid #f3f4f6}.detail-item span{flex:1;word-break:break-word}.modal-content{background:#fff;border-radius:12px;width:95%;max-width:800px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;margin-bottom:20px}.close-modal-btn{background:none;border:none;color:#6b7280;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.close-modal-btn:hover{background:#f3f4f6;color:#374151}.supplier-form{padding:0 24px 24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#374151;font-weight:500;font-size:14px}.form-group input,.form-group textarea{padding:12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group textarea.error{border-color:#dc2626}.error-text{color:#dc2626;font-size:12px;margin-top:4px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.cancel-btn{padding:12px 20px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:14px}.cancel-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.submit-btn{padding:12px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.submit-btn:hover:not(:disabled){background:#2563eb}.submit-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.suppliers-screen{padding:16px}.screen-header{flex-direction:column;gap:16px;align-items:stretch}.screen-header h2{font-size:24px}.suppliers-controls{flex-direction:column;gap:12px}.search-box{max-width:none}.suppliers-grid{grid-template-columns:1fr;gap:16px}.supplier-card,.modal-overlay{padding:16px}.modal-content{max-height:95vh}.modal-header{padding:20px 20px 0}.supplier-form{padding:0 20px 20px}.form-row{grid-template-columns:1fr;gap:16px}.form-actions{flex-direction:column}}@media (max-width: 480px){.suppliers-screen{padding:12px}.screen-header h2{font-size:20px}.add-supplier-btn,.add-first-supplier-btn{padding:10px 16px;font-size:13px}.supplier-card{padding:12px}.supplier-name h3{font-size:16px}.modal-header{padding:16px 16px 0}.modal-header h3{font-size:18px}.supplier-form{padding:0 16px 16px}}.promotions-screen{padding:20px;max-width:1400px;margin:0 auto}.promotions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.promotions-header h2{color:#333;margin:0;font-size:1.8rem}.promotions-controls{display:flex;gap:15px;margin-bottom:20px;align-items:center}.search-box{flex:1;max-width:400px}.search-box input{width:100%;padding:10px 15px;border:2px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease}.search-box input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:5px}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#1e7e34}.btn-warning{background-color:#ffc107;color:#212529}.btn-warning:hover{background-color:#e0a800}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover{background-color:#138496}.btn-small{padding:5px 10px;font-size:12px;min-width:35px;justify-content:center}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.promotions-screen .modal{background:#fff;border-radius:12px;padding:0;width:95%;max-width:900px;max-height:85vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h3{margin:0;color:#333;font-size:1.4rem}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-btn:hover{background-color:#e0e0e0;color:#333}.promotion-form{padding:20px}.form-row{display:flex;gap:15px;margin-bottom:15px}.form-group{flex:1;display:flex;flex-direction:column}.form-group label{margin-bottom:5px;font-weight:500;color:#333;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:10px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.promotions-table{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.promotions-table table{width:100%;border-collapse:collapse}.promotions-table th{background-color:#f8f9fa;padding:15px 12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;font-size:14px}.promotions-table td{padding:12px;border-bottom:1px solid #f0f0f0;font-size:14px;vertical-align:middle}.promotions-table tr.active-promotion{background-color:#e8f5e8}.promotions-table tr.active-promotion:hover{background-color:#d4edda}.promotion-name{font-weight:600;color:#333}.promotion-description{color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.promotion-discount{font-weight:600;color:#28a745;font-size:16px}.promotion-dates{font-size:12px;color:#666}.promotion-dates div:first-child{font-weight:500;color:#333}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.status.active{background-color:#d4edda;color:#155724}.status.inactive{background-color:#f8d7da;color:#721c24}.actions{display:flex;gap:5px;justify-content:center}.modal-actions{padding:15px 20px;border-bottom:1px solid #eee;background-color:#f8f9fa}.search-section{padding:15px 20px;border-bottom:1px solid #eee}.search-input{width:100%;padding:10px 15px;border:2px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.products-list{padding:20px;max-height:400px;overflow-y:auto;overflow-x:auto}.products-table{width:100%;border-collapse:collapse;margin-top:10px;min-width:900px}.products-table th{background-color:#f8f9fa;padding:12px 15px;text-align:left;font-weight:600;color:#333;border-bottom:1px solid #ddd;white-space:nowrap}.products-table td{padding:12px 15px;text-align:left;border-bottom:1px solid #ddd;font-size:13px;white-space:nowrap}.products-table tr:hover{background-color:#f8f9fa}.btn-success{background-color:#28a745;color:#fff;border:none}.btn-success:hover{background-color:#218838}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:18px;color:#666}.no-data{text-align:center;padding:40px 20px;color:#666;font-size:16px;background-color:#f8f9fa}.notification{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;color:#fff;font-weight:500;z-index:1001;box-shadow:0 4px 12px #0003;animation:slideIn .3s ease}.notification.success{background-color:#28a745}.notification.error{background-color:#dc3545}@media (max-width: 1200px){.promotions-screen .modal{width:calc(100vw - 20px)!important;max-width:none!important}.modal-overlay{padding:10px}}@media (max-width: 768px){.promotions-screen{padding:10px}.promotions-header{flex-direction:column;gap:15px;align-items:stretch}.form-row{flex-direction:column}.promotions-table{overflow-x:auto}.promotions-table table{min-width:800px}.promotions-screen .modal{width:calc(100vw - 10px)!important;max-width:none!important;max-height:calc(100vh - 10px)}.modal-overlay{padding:5px}.products-list{padding:15px;max-height:350px}.products-table{min-width:700px}.products-table th,.products-table td{padding:8px 10px;font-size:12px}.form-actions{flex-direction:column}.actions{flex-wrap:wrap}}.form-group.full-width{grid-column:1 / -1}.days-selector{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.day-checkbox{display:flex;align-items:center;cursor:pointer;padding:8px 12px;border-radius:6px;background:#fff;border:2px solid #dee2e6;transition:all .3s ease;-webkit-user-select:none;user-select:none;min-width:90px;justify-content:center}.day-checkbox:hover{border-color:#007bff;background:#f0f8ff}.day-checkbox input[type=checkbox]{margin:0 6px 0 0;transform:scale(1.1)}.day-checkbox input[type=checkbox]:checked+.day-label{color:#007bff;font-weight:600}.day-checkbox:has(input:checked){background:#e3f2fd;border-color:#007bff;box-shadow:0 2px 4px #007bff33}.day-label{font-size:.9rem;font-weight:500;color:#495057;transition:all .3s ease}.form-help{display:block;margin-top:8px;font-size:.85rem;color:#6c757d;font-style:italic}.weekly-days{font-size:.9rem;color:#495057;font-weight:500}.promotion-days{text-align:center;min-width:120px}@media (max-width: 768px){.days-selector{gap:8px}.day-checkbox{min-width:70px;padding:6px 8px;font-size:.85rem}}.group-promotions-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:25px;margin-bottom:30px;box-shadow:0 8px 25px #667eea4d;color:#fff}.group-promotions-section h3{margin:0 0 20px;font-size:1.5rem;font-weight:600;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.2)}.group-promotions-container{display:flex;flex-direction:column;gap:20px}.group-promotion-card{background:#fffffff2;border-radius:12px;padding:20px;color:#333;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.group-promotion-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.group-promotion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e8f4fd}.group-promotion-header h4{margin:0;color:#2c3e50;font-size:1.2rem;font-weight:600}.group-discount-amount{background:linear-gradient(45deg,#28a745,#20c997);color:#fff;padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px;box-shadow:0 2px 8px #28a7454d}.group-promotion-details{display:flex;flex-direction:column;gap:15px}.promotion-description{color:#6c757d;font-style:italic;margin:0;font-size:14px}.qualifying-products h5{margin:0 0 10px;color:#495057;font-size:16px;font-weight:600}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.qualifying-product{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:12px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.qualifying-product:hover{background:#e8f4fd;border-color:#007bff;transform:translateY(-1px)}.product-name{font-weight:500;color:#333;flex:1;margin-right:10px}.product-quantity{background:#007bff;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;margin-right:8px}.product-discount{color:#28a745;font-weight:600;font-size:14px}.promotion-summary{background:#f8f9fa;border-radius:8px;padding:15px;border-left:4px solid #007bff}.summary-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.summary-item:last-child{margin-bottom:0}.summary-item span:first-child{color:#6c757d;font-weight:500}.summary-item span:last-child{font-weight:600;color:#333}.total-savings{border-top:2px solid #e9ecef;padding-top:10px;margin-top:10px}.total-savings span:last-child{color:#28a745;font-size:16px;font-weight:700}.total-group-savings{background:#fffffff2;border-radius:12px;padding:20px;text-align:center;border:3px solid #ffd700;box-shadow:0 4px 15px #ffd7004d}.total-group-savings h4{margin:0;color:#2c3e50;font-size:1.3rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}@media (max-width: 768px){.group-promotions-section{padding:15px;margin-bottom:20px}.group-promotion-header{flex-direction:column;gap:10px;align-items:stretch;text-align:center}.products-grid{grid-template-columns:1fr}.qualifying-product{flex-direction:column;gap:8px;text-align:center}.product-name{margin-right:0}.group-promotions-section h3{font-size:1.2rem}.total-group-savings h4{font-size:1.1rem}}.product-selector-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.product-selector{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:1200px;height:85vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e5e7eb}.selector-header{background:#fff;padding:16px 24px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.selector-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:10px}.close-btn{background:transparent;border:none;color:#94a3b8;font-size:28px;cursor:pointer;line-height:1;padding:4px;border-radius:4px;transition:color .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.close-btn:hover{color:#1e293b;background:#f1f5f9}.selector-content{display:flex;flex:1;overflow:hidden;background:#f8fafc}.left-panel{flex:1;display:flex;flex-direction:column;padding:20px;overflow:hidden;min-width:0}.selection-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;color:#64748b;font-size:.9rem;padding:0 4px}.count-selected{color:#2563eb;font-weight:600}.product-grid{display:grid;grid-template-columns:1fr;gap:12px;overflow-y:auto;padding-right:4px}.product-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:flex-start;gap:12px;position:relative}.product-card:hover{border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 12px #0000000d}.product-card.selected{border-color:#2563eb;background-color:#eff6ff;box-shadow:0 2px 4px #2563eb1a}.product-card input[type=checkbox]{width:18px;height:18px;accent-color:#2563eb;margin-top:3px;cursor:pointer}.product-info{flex:1;min-width:0}.product-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}.product-name{font-weight:500;color:#0f172a;font-size:.95rem;line-height:1.4}.product-price{font-weight:600;color:#0f172a;font-size:.95rem}.product-details{display:flex;flex-direction:column;gap:2px}.product-type,.product-code,.parent-info{font-size:.8rem;color:#64748b}.parent-info{color:#7c3aed}.right-panel{width:320px;background:#fff;border-left:1px solid #f1f5f9;display:flex;flex-direction:column;padding:20px;gap:24px;overflow-y:auto;box-shadow:-4px 0 20px #00000005}.controls-section{display:flex;flex-direction:column;gap:16px}.search-field{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;transition:border-color .2s;background:#f8fafc;color:#334155}.search-field:focus{outline:none;border-color:#2563eb;background:#fff}.filter-dropdown,.sort-dropdown{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;background-color:#fff;color:#334155;cursor:pointer}.filter-dropdown:focus,.sort-dropdown:focus{outline:none;border-color:#2563eb}.bulk-controls{display:flex;gap:10px}.bulk-btn{flex:1;padding:8px;background:#f1f5f9;border:none;border-radius:6px;font-size:.8rem;color:#475569;cursor:pointer;font-weight:500;transition:background .2s}.bulk-btn:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.selected-section{flex:1;display:flex;flex-direction:column;min-height:0;border-top:1px solid #f1f5f9;padding-top:20px}.selected-section h4{margin:0 0 12px;font-size:.9rem;color:#475569;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.selected-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding-right:4px}.selected-tag{display:flex;justify-content:space-between;align-items:center;background:#f1f5f9;padding:8px 12px;border-radius:6px;font-size:.85rem;color:#334155}.remove-btn{background:transparent;border:none;color:#94a3b8;cursor:pointer;font-size:16px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.remove-btn:hover{background:#e2e8f0;color:#ef4444}.selector-actions{margin-top:auto;display:flex;gap:12px;padding-top:20px;border-top:1px solid #f1f5f9}.cancel-btn{padding:10px 20px;background:transparent;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;font-weight:500;cursor:pointer}.cancel-btn:hover{background:#f8fafc;color:#1e293b;border-color:#cbd5e1}.confirm-btn{flex:1;padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.confirm-btn:hover:not(:disabled){background:#1d4ed8}.confirm-btn:disabled{background:#94a3b8;cursor:not-allowed;opacity:.7}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 900px){.selector-content{flex-direction:column}.right-panel{width:100%;height:300px;border-left:none;border-top:1px solid #e2e8f0}}@media (max-width: 600px){.product-grid{grid-template-columns:1fr}}.product-selection-section{display:flex;flex-direction:column;gap:16px;background:#f8fafc;padding:16px;border-radius:8px;border:1px dashed #cbd5e1}.btn-select-products{background:transparent;color:#2563eb;border:1px solid #2563eb;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;align-self:flex-start;display:flex;align-items:center;gap:8px}.btn-select-products:hover{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.btn-select-products:before{content:"+";font-size:1.2em;line-height:1}.selected-products-preview{display:flex;flex-direction:column;gap:12px}.selected-products-preview h4{margin:0;font-size:.85rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.selected-products-tags{display:flex;flex-wrap:wrap;gap:8px}.product-tag{background:#fff;border:1px solid #e2e8f0;color:#334155;border-radius:20px;padding:6px 12px;font-size:.85rem;display:flex;align-items:center;gap:8px;box-shadow:0 1px 2px #0000000d;font-weight:500}.remove-product-tag{background:transparent;color:#94a3b8;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;line-height:1;padding:0;transition:all .2s}.remove-product-tag:hover{background:#f1f5f9;color:#ef4444}.business-config-screen{padding:20px;max-width:1200px;margin:0 auto;background:#f8f9fa;min-height:100vh}.business-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.header-title{display:flex;align-items:center;gap:12px}.header-title h1{margin:0;color:#2c3e50;font-size:28px;font-weight:600}.header-actions{display:flex;gap:12px}.alert{padding:16px;border-radius:8px;margin-bottom:20px;font-weight:500}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;min-height:400px;width:100%}.business-loading-wrapper{display:flex;flex-direction:column;align-items:center;gap:16px}.business-spinner{width:48px;height:48px;border:4px solid rgba(66,133,244,.1);border-left-color:#4285f4;border-radius:50%;animation:spin 1s linear infinite;background:transparent;display:block}.error-container{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.error-container h2{color:#e74c3c;margin-bottom:16px}.error-container p{color:#6c757d;font-size:16px}.business-config-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.empty-state{text-align:center;padding:80px 40px}.empty-state svg{color:#6c757d;margin-bottom:24px}.empty-state h2{color:#2c3e50;margin-bottom:12px;font-size:24px}.empty-state p{color:#6c757d;margin-bottom:32px;font-size:16px;line-height:1.5}.business-config-form{padding:40px}.form-section{margin-bottom:40px}.form-section:last-child{margin-bottom:0}.form-section h3{color:#2c3e50;margin-bottom:24px;font-size:20px;font-weight:600;padding-bottom:8px;border-bottom:2px solid #e9ecef}.form-group{margin-bottom:24px}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:600;color:#2c3e50;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:border-color .3s ease,box-shadow .3s ease;background:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 3px #4285f41a}.form-group input:disabled,.form-group textarea:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.logo-section{display:flex;gap:32px;align-items:flex-start}.logo-preview{flex-shrink:0;width:160px;height:120px;border:2px dashed #dee2e6;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;overflow:hidden}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px}.logo-placeholder{text-align:center;color:#6c757d}.logo-placeholder svg{margin-bottom:8px}.logo-placeholder p{margin:0;font-size:14px}.logo-upload{flex:1}.upload-label{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#4285f4;color:#fff;border-radius:8px;cursor:pointer;font-weight:500;transition:background .3s ease;margin-bottom:12px}.upload-label:hover{background:#3367d6}.upload-help{color:#6c757d;font-size:14px;line-height:1.4;margin:0}.form-actions{display:flex;gap:16px;justify-content:flex-end;padding-top:32px;border-top:1px solid #e9ecef;margin-top:32px}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;min-width:120px;justify-content:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#4285f4;color:#fff}.btn-primary:hover:not(:disabled){background:#3367d6;transform:translateY(-1px);box-shadow:0 4px 12px #4285f44d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px #6c757d4d}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}.btn-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.business-config-screen{padding:16px}.business-config-header{flex-direction:column;gap:16px;align-items:flex-start}.header-actions{width:100%;justify-content:flex-end}.business-config-form{padding:24px}.logo-section{flex-direction:column;gap:20px}.logo-preview{width:100%;max-width:200px;margin:0 auto}.form-actions{flex-direction:column}.btn{width:100%}}@media (max-width: 480px){.header-title h1{font-size:24px}.business-config-form{padding:20px}.empty-state{padding:40px 20px}.empty-state h2{font-size:20px}}.gnpos-admin-screen{padding:1rem;background:#f1f5f9;min-height:100vh;font-family:system-ui,-apple-system,sans-serif}.screen-header{margin-bottom:1.5rem}.header-title{display:flex;align-items:center;gap:.75rem}.header-title svg{flex-shrink:0;color:#3b82f6}.header-title h1{font-size:1.5rem;font-weight:600;color:#0f172a;margin:0;letter-spacing:-.02em}.header-subtitle{color:#64748b;font-size:.875rem;margin-top:.25rem}.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-card{background:#fff;padding:1rem;border-radius:8px;border:1px solid #e2e8f0;display:flex;align-items:center;gap:.75rem}.stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8fafc;color:#64748b;flex-shrink:0}.stat-card:nth-child(1) .stat-icon{color:#3b82f6}.stat-card:nth-child(2) .stat-icon{color:#16a34a}.stat-card:nth-child(3) .stat-icon{color:#ca8a04}.stat-card:nth-child(4) .stat-icon{color:#64748b}.stat-info h3{margin:0;font-size:.75rem;color:#94a3b8;font-weight:500}.stat-info p{margin:.2rem 0 0;font-size:1.25rem;font-weight:600;color:#0f172a}.section-container{background:#fff;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:1rem;overflow:hidden}.section-header{padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.section-header h2{margin:0;font-size:1rem;font-weight:600;color:#0f172a}.section-header input{padding:.5rem .75rem .5rem 2.25rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;max-width:280px}.gnpos-search-wrap{position:relative}.gnpos-search-wrap svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#94a3b8;width:16px;height:16px}.gnpos-table-wrap{overflow-x:auto}.gnpos-admin-screen table{width:100%;border-collapse:collapse}.gnpos-admin-screen th{background:#f8fafc;padding:.75rem 1rem;text-align:left;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e2e8f0}.gnpos-admin-screen td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;color:#334155;font-size:.875rem}.gnpos-admin-screen tr:last-child td{border-bottom:none}.user-cell{display:flex;flex-direction:column;gap:.125rem}.user-name{font-weight:500;color:#0f172a}.user-email{font-size:.75rem;color:#64748b}.status-badge{display:inline-flex;padding:.2rem .6rem;border-radius:9999px;font-size:.7rem;font-weight:500;white-space:nowrap}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.pending{background:#fef9c3;color:#854d0e}.status-badge.expired,.status-badge.inactive{background:#f1f5f9;color:#64748b}.status-badge.cancelled{background:#f1f5f9;color:#94a3b8}.action-btn{padding:.4rem;border-radius:6px;border:none;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;justify-content:center;background:#f8fafc;color:#64748b}.action-btn:hover{background:#e2e8f0;color:#334155}.action-btn.approve{background:#dcfce7;color:#16a34a}.action-btn.approve:hover{background:#bbf7d0}.action-btn.reject{background:#fee2e2;color:#dc2626}.action-btn.reject:hover{background:#fecaca}.action-group{display:flex;gap:.35rem;flex-wrap:wrap}.section-pending .section-header{background:#fffbeb;border-color:#fde68a}.section-pending .section-header h2{color:#92400e}.gnpos-user-cards{display:none}.gnpos-user-card{padding:1rem;border-bottom:1px solid #f1f5f9}.gnpos-user-card:last-child{border-bottom:none}.gnpos-user-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.gnpos-user-card-info .user-name{font-size:1rem}.gnpos-user-card-info .user-email{font-size:.8rem}.gnpos-user-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.8rem;color:#64748b}.gnpos-user-card-meta span{display:flex;align-items:center;gap:.25rem}.gnpos-user-card-actions{display:flex;gap:.35rem;flex-wrap:wrap}.gnpos-pending-cards{display:none}.gnpos-pending-card{padding:1rem;border-bottom:1px solid #fef3c7}.gnpos-pending-card:last-child{border-bottom:none}.gnpos-subuser-cards{display:none}.gnpos-subuser-card{padding:1rem;border-bottom:1px solid #f1f5f9;background:#f8fafc;border-radius:8px;margin-bottom:.5rem}.gnpos-subuser-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.gnpos-subuser-card-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:#64748b;margin-bottom:.75rem}.gnpos-subuser-card-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.modal-overlay{position:fixed;inset:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;padding:1.25rem;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#0f172a;word-break:break-word}.modal-header .modal-close{background:none;border:none;cursor:pointer;padding:.25rem;color:#64748b;border-radius:6px}.modal-header .modal-close:hover{background:#f1f5f9;color:#334155}.modal-body{flex:1;overflow-y:auto;padding:1rem 0;min-height:0}.modal-actions{padding-top:1rem;border-top:1px solid #f1f5f9;flex-shrink:0;display:flex;gap:.5rem;justify-content:flex-end}.permissions-editor{display:flex;flex-wrap:wrap;gap:.25rem}.permission-toggle{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .4rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:.7rem;color:#475569;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none;white-space:nowrap}.permission-toggle:hover{background:#f1f5f9}.permission-toggle.active{background:#eff6ff;border-color:#93c5fd;color:#2563eb}.permission-toggle input{accent-color:#2563eb;width:12px;height:12px;flex-shrink:0}.permissions-view{display:flex;flex-wrap:wrap;gap:.2rem}.permission-badge-view{padding:.15rem .4rem;background:#f1f5f9;border-radius:4px;font-size:.68rem;color:#475569}.gnpos-date-modal{max-width:400px}.gnpos-modal-desc{margin:0 0 1rem;color:#475569;font-size:.9rem}.gnpos-form-label{display:block;margin-bottom:.5rem;font-weight:500;color:#334155;font-size:.875rem}.gnpos-date-input{width:100%;padding:.65rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;box-sizing:border-box}.gnpos-modal-hint{margin:.75rem 0 0;font-size:.8rem;color:#94a3b8}.gnpos-btn-primary{padding:.5rem 1rem;border-radius:6px;background:#2563eb;color:#fff;border:none;cursor:pointer;font-weight:500}.gnpos-btn-primary:hover{background:#1d4ed8}.gnpos-btn-secondary{padding:.5rem 1rem;border-radius:6px;background:#fff;color:#475569;border:1px solid #e2e8f0;cursor:pointer}.gnpos-btn-secondary:hover{background:#f8fafc}.gnpos-empty-msg{color:#64748b;margin:0;font-size:.9rem}.gnpos-mono{font-family:ui-monospace,monospace;font-size:.75rem;color:#64748b}.gnpos-muted{color:#94a3b8;font-style:italic;font-size:.85rem}.subuser-add{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.subuser-add-label{display:block;font-size:.8rem;font-weight:500;color:#475569;margin-bottom:.35rem}.subuser-add-input{width:100%;max-width:320px;padding:.5rem .6rem;border-radius:6px;border:1px solid #e2e8f0;font-size:.85rem;box-sizing:border-box}.subuser-add-input:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 1px #bfdbfe}.subuser-add-results{margin-top:.5rem;max-width:320px;border-radius:8px;border:1px solid #e2e8f0;background:#f9fafb;max-height:220px;overflow-y:auto}.subuser-add-item{width:100%;padding:.4rem .6rem;border:none;background:transparent;text-align:left;display:flex;flex-direction:column;gap:.1rem;cursor:pointer}.subuser-add-item:hover{background:#e5e7eb}.subuser-add-name{font-size:.85rem;color:#111827}.subuser-add-email{font-size:.75rem;color:#6b7280}.loading-spinner{text-align:center;padding:3rem;color:#64748b;font-size:.9rem}@media (max-width: 768px){.gnpos-admin-screen{padding:.75rem}.admin-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.stat-card{padding:.75rem}.stat-icon{width:36px;height:36px}.stat-info p{font-size:1.1rem}.section-header{flex-direction:column;align-items:stretch}.section-header input{max-width:none}.gnpos-table-wrap{display:none}.gnpos-user-cards,.gnpos-pending-cards,.gnpos-subuser-cards{display:block}.gnpos-user-card,.gnpos-pending-card,.gnpos-subuser-card{padding:1rem 1.25rem}.gnpos-user-card-actions .action-btn,.gnpos-pending-card-actions .action-btn{padding:.5rem}.modal-overlay{padding:0;align-items:stretch}.modal{max-height:100vh;border-radius:0;padding:1rem}.permissions-editor{gap:.2rem}}@media (min-width: 769px) and (max-width: 1024px){.admin-grid{grid-template-columns:repeat(2,1fr)}}.accounts-layout{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}@media (max-width: 960px){.accounts-layout{grid-template-columns:1fr}}.filters-bar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px;position:sticky;top:0;z-index:5;background:linear-gradient(180deg,#fff,#fbfdff);padding:10px 12px;border:1px solid #e9eef5;border-radius:10px;box-shadow:0 4px 14px #0208140a}.filters-bar .filter-group{display:flex;align-items:center;gap:8px}.filters-bar .filter-group.stacked{flex-direction:column;align-items:flex-start;gap:4px}.filters-bar .filter-group.date-range{gap:10px;align-items:flex-end}.filters-bar .filters-status{margin-left:auto}.filters-bar .tiny{font-size:12px;opacity:.8}.filters-bar .date-inputs{display:flex;align-items:flex-end;gap:8px}.filters-bar .date-inputs input[type=date]{padding:6px 8px;border:1px solid #dfe3ea;border-radius:8px;background:#fff}.segmented{display:inline-flex;border:1px solid #ddd;border-radius:8px;overflow:hidden;background:#fff}.segmented button{padding:6px 12px;background:#fff;border:none;border-right:1px solid #eee;cursor:pointer}.segmented button:last-child{border-right:none}.segmented button.active{background:#eef6ff;color:#0550ae;font-weight:600}.segmented button:disabled{opacity:.6;cursor:not-allowed}.date-range-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.date-range-group .date-inputs{display:flex;align-items:center;gap:8px}.date-range-group label{display:flex;align-items:center;gap:6px}.date-range-group label.stacked{flex-direction:column;align-items:flex-start;gap:2px}.date-range-group .tiny{font-size:11px;opacity:.75}.btn.subtle{padding:6px 8px;border:1px solid #eaecef;background:#fafbfc}.saldo-box{display:flex;gap:16px;flex-wrap:wrap;background:#f8fafc;border:1px solid #e6edf3;border-radius:10px;padding:10px 12px}.saldo-item{display:flex;gap:8px;align-items:baseline}.saldo-item .label{font-weight:600;color:#0b1736}.saldo-item .value{font-size:16px}.saldo-pendiente .value{color:#b00020}.saldo-post .value{color:#1b5e20}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:4px 10px;border:1px solid #ddd;border-radius:999px;background:#fff;cursor:pointer;font-size:12px}.chip:hover{background:#f6f8fa}.chip:disabled{opacity:.6;cursor:not-allowed}.badge{display:inline-block;padding:2px 6px;border-radius:6px;font-size:12px;margin-right:8px}.badge.sale{background:#e7f5ff;color:#0b7285}.badge.payment{background:#eafbea;color:#1b5e20}.summary-card{border:1px solid #ddd;border-radius:8px;padding:12px;background:#fff;box-shadow:0 1px 2px #0000000a}.summary-card .title{font-weight:600}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.muted{font-size:12px;opacity:.8}.error{color:#b00020}.success{color:#1b5e20}.accounts-screen .screen-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.accounts-screen .header-actions button{padding:8px 12px;border-radius:8px;border:1px solid #ddd;background:#fff;cursor:pointer}.accounts-screen .header-actions button:disabled{opacity:.6;cursor:not-allowed}.payment-card{border:1px solid #e6edf3;border-radius:12px;background:#fff;padding:12px;box-shadow:0 1px 2px #0208140d}.client-panel-card{border:1px solid #e6edf3;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);padding:14px;box-shadow:0 8px 24px #0208140f}.client-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:8px;border-bottom:1px solid #eef3f8}.client-id{display:flex;align-items:center;gap:10px}.avatar-circle{width:36px;height:36px;border-radius:999px;background:#eef6ff;color:#0550ae;display:flex;align-items:center;justify-content:center;font-weight:700}.client-meta .name{font-weight:700}.client-meta .stats{font-size:12px;opacity:.85}.client-meta .stats .divider{margin:0 6px;opacity:.6}.client-actions .btn{padding:6px 10px}.client-panel-card .section{margin-top:10px}.saldo-box.elevated{background:#f1f7ff;border-color:#dbe9ff}.placeholder-card{border:1px dashed #c7d2e0;border-radius:12px;background:#f8fafc;padding:16px;text-align:center}.placeholder-title{font-weight:600;margin-bottom:8px}.placeholder-actions{display:flex;gap:8px;justify-content:center}.client-chip{display:inline-flex;align-items:center;gap:8px;background:#f3f9ff;border:1px solid #d8e8ff;color:#0b1736;padding:6px 10px;border-radius:999px}.client-chip .label{font-size:12px;opacity:.75}.client-chip .value{font-weight:600}.btn.small{padding:4px 8px;border-radius:8px;border:1px solid #ddd;background:#fff}.payment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px}.payment-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.movements-section{margin-top:24px}.pagination-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.pagination-bar .left,.pagination-bar .right{display:flex;align-items:center;gap:8px}.pagination-bar .btn{padding:6px 10px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer}.pagination-bar .btn:disabled{opacity:.6;cursor:not-allowed}.movements-table{width:100%;border-collapse:collapse;background:#fff}.movements-table thead th{text-align:left;border-bottom:1px solid #ddd;padding:8px;position:sticky;top:40px;background:#fff;z-index:4}.movements-table tbody td{border-bottom:1px solid #f0f0f0;padding:8px}.movements-table tbody tr:nth-child(2n){background:#fcfdff}.movements-table tbody tr:hover{background:#f7faff}.movements-table .num{text-align:right}.empty-state{padding:12px;text-align:center;opacity:.7}tr.row-sale{border-left:3px solid #0b7285}tr.row-payment{border-left:3px solid #1b5e20}.date-cell .sub,.items-table .sub{font-size:12px;opacity:.75}.items-panel{padding:8px;background:#fafafa}.items-table{width:100%;border-collapse:collapse}.items-table thead th{text-align:left;border-bottom:1px solid #ddd;padding:6px}.items-table tbody td{border-bottom:1px solid #eee;padding:6px}.items-table .num{text-align:right}.items-table tfoot .label{font-weight:700}.items-table tfoot td{font-weight:600;background:#f4f8ff;border-top:1px solid #dfe7f3}.totals-row td{padding-top:8px;padding-bottom:8px}.btn-link{border:none;background:transparent;color:#0550ae;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.items-modal .modal{max-width:980px;width:calc(100vw - 48px);max-height:85vh;display:flex;flex-direction:column}.items-modal .modal-header,.items-modal .modal-footer{flex:0 0 auto}.items-modal .modal-body{flex:1 1 auto;overflow:auto}.items-modal .items-table{width:100%;border-collapse:collapse;table-layout:auto}.items-modal .items-table thead th,.items-modal .items-table tbody td,.items-modal .items-table tfoot td{padding:8px}.items-modal .items-table .num{text-align:right}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:20px;border-radius:8px;max-width:600px;width:100%;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:20px}.modal-header h2{margin:0}.modal-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer}.modal-body{margin-bottom:20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #eee;padding-top:10px}*{box-sizing:border-box}.app{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column;opacity:0;animation:fadeInApp .3s ease-in-out .1s forwards}@keyframes fadeInApp{0%{opacity:0}to{opacity:1}}.app-nav{position:sticky;top:0;z-index:100;background:#042959;color:#fff;padding:0 2rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;box-shadow:0 2px 4px #0000001a;min-height:70px;gap:1rem}.nav-brand h1{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.current-screen-indicator{font-size:.9rem;color:#bdc3c7;margin-top:4px;font-weight:500;transition:all .3s ease;opacity:.8;text-align:center;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.current-screen-indicator:hover{opacity:1;color:#ecf0f1}.nav-left{display:flex;align-items:center;justify-content:flex-start}.nav-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.nav-right{display:flex;align-items:center;justify-content:flex-end}@media (max-width: 768px){.app-nav{padding:0 1rem;grid-template-columns:auto 1fr;gap:.5rem}.nav-brand h1{font-size:1.25rem}.nav-right{display:none}}@media (max-width: 480px){.app-nav{padding:0 .5rem;grid-template-columns:auto 1fr}.nav-brand h1{font-size:1.1rem}.current-screen-indicator{font-size:.8rem}}@media (max-width: 768px){.item-controls-inline{flex-direction:column;align-items:stretch;gap:12px}.item-pricing-simplified{flex-direction:row;justify-content:space-between;align-items:center}.item-actions{justify-content:center}}.app-main{flex:1;overflow-y:auto}.sales-screen{height:100vh;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden}.scanner-input{position:absolute;top:-9999px;left:-9999px;opacity:0;pointer-events:none}.sales-toolbar{background:#fff;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;border-bottom:1px solid #e0e0e0;flex-shrink:0}.scanner-status-compact{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:#6b7280;opacity:.8}.scanner-dot{width:3px;height:3px;border-radius:50%;background:#ef4444;flex-shrink:0}.scanner-dot.ready{background:#22c55e}.scanner-dot.loading{background:#f59e0b;animation:subtle-pulse 2s infinite}.scanner-text{font-weight:400;letter-spacing:.01em}@keyframes subtle-pulse{0%,to{opacity:.4}50%{opacity:.7}}.notification{background:#22c55e;color:#fff;padding:.5rem 1.5rem;text-align:center;animation:slideDown .3s ease;flex-shrink:0}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.scanner-toast-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:10000;pointer-events:none;animation:scannerToastFadeIn .25s ease-out forwards}.scanner-toast-modal{background:#fff;border-radius:20px;padding:3rem 4rem;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;text-align:center;max-width:95%;min-width:320px;animation:scannerToastScaleIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.scanner-toast-name{font-size:2rem;font-weight:700;color:#1f2937;line-height:1.3;margin-bottom:.75rem}.scanner-toast-price{font-size:2.5rem;font-weight:800;color:#16a34a;margin-bottom:.35rem}.scanner-toast-qty{font-size:1.5rem;font-weight:600;color:#6b7280}@keyframes scannerToastFadeIn{0%{background:#0000}to{background:#00000026}}@keyframes scannerToastScaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.sales-content{flex:1;display:grid;grid-template-columns:1fr 380px;gap:1rem;padding:.75rem 1rem;max-width:1600px;margin:0 auto;width:100%;height:100%;overflow:hidden;min-height:0}.cart-section{background:#fff;border-radius:12px;padding:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;display:flex;flex-direction:column;height:100%;overflow:hidden}.cart-header{padding:.75rem 1rem .5rem;border-bottom:1px solid #f3f4f6;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px 8px 0 0;flex-shrink:0}.cart-title{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem}.cart-icon{width:24px;height:24px;color:#2563eb}.cart-title h2{margin:0;color:#1f2937;font-size:1.1rem;font-weight:600}.cart-summary{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#fff;border-radius:6px;border:1px solid #e5e7eb}.item-count{font-size:.9rem;color:#6b7280;font-weight:500}.quick-total{font-size:1.1rem;font-weight:700;color:#2563eb}.empty-cart{padding:1.5rem 1.25rem;flex:1;display:flex;align-items:center;justify-content:center}.empty-cart-content{text-align:center;color:#6b7280}.empty-cart-content h3{margin:1rem 0 .5rem;color:#374151;font-size:1.1rem}.empty-cart-content p{margin:0;font-size:.9rem}.empty-cart-content kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:2px 6px;font-size:.8rem;font-weight:600}.empty-icon{width:48px;height:48px;margin:0 auto;opacity:.4;color:#9ca3af}.cart-items{display:flex;flex-direction:column;gap:0;flex:1;overflow-y:auto;padding:0;min-height:0}.cart-item{border-bottom:1px solid #f3f4f6;padding:.625rem 1rem;background:#fff;transition:all .2s ease;position:relative}.cart-item:hover{background:#f8fafc}.cart-item:last-child{border-bottom:none;border-radius:0 0 12px 12px}.cart-item.has-promotion{background:linear-gradient(135deg,#fef3c7,#fffbeb);border-left:4px solid #f59e0b}.cart-item.has-group-promotion{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:4px solid #0ea5e9}.cart-item.has-promotion.has-group-promotion{background:linear-gradient(135deg,#fef3c7,#f0f9ff,#e0f2fe);border-left:4px solid #8b5cf6}.item-main-simplified,.item-basic-info{display:flex;flex-direction:column;gap:12px}.product-name-section{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem}.product-name{margin:0;font-size:1rem;font-weight:600;color:#1f2937;line-height:1.2;flex:1}.quantity-badge{background:#2563eb;color:#fff;font-size:.8rem;font-weight:700;padding:.25rem .5rem;border-radius:12px;min-width:24px;text-align:center;line-height:1}.item-controls-inline{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.item-pricing-simplified{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:100px}.unit-price-simple{font-size:.9rem;color:#666;font-weight:500}.item-total-price{font-size:1.2rem;font-weight:700;color:#2563eb;padding:.25rem .5rem;background:#eff6ff;border-radius:6px;border:1px solid #dbeafe}.item-actions{display:flex;gap:8px;align-items:center}.details-btn{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;padding:6px 8px;border-radius:4px;transition:all .2s ease;cursor:pointer}.details-btn:hover{background:#e9ecef;border-color:#adb5bd}.item-details-expanded{margin-top:12px;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.detail-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:4px 0}.detail-row:last-child{margin-bottom:0}.detail-label{font-weight:600;color:#495057;font-size:.9rem;min-width:120px}.detail-value{color:#333;font-size:.9rem;text-align:right;flex:1}.promotion-detail .detail-value{color:#155724;font-weight:500}.group-promotion-detail .detail-value{color:#004085;font-weight:500}.price-detail .detail-value.original-price{text-decoration:line-through;color:#999}.barcode{font-size:.8rem;color:#6b7280;font-family:Courier New,monospace;background:#f3f4f6;padding:2px 6px;border-radius:4px;font-weight:500}.subproduct-info{margin-top:.375rem}.usage-info{font-size:.75rem;color:#059669;background:#ecfdf5;padding:3px 6px;border-radius:4px;font-weight:500;display:inline-block}.item-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.375rem}.item-info{flex:1;min-width:0}.item-pricing{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.375rem}.price-display{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.original-price{font-size:.8rem;color:#6b7280;text-decoration:line-through;font-weight:500}.unit-price{font-size:.9rem;color:#374151;font-weight:600}.promotions-section{margin:.5rem 0 .375rem;padding:.5rem;background:#ffffffb3;border-radius:6px;border:1px solid rgba(255,255,255,.5)}.promotion-info,.group-promotion-info{margin-bottom:.375rem}.promotion-info:last-child,.group-promotion-info:last-child{margin-bottom:0}.promotion-tag{font-size:.8rem;color:#92400e;background:#fbbf2433;padding:4px 8px;border-radius:6px;font-weight:600;display:inline-block}.group-promotion-tag{font-size:.8rem;color:#0c4a6e;background:#0ea5e933;padding:4px 8px;border-radius:6px;font-weight:600;display:inline-block}.item-controls{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.375rem;border-top:1px solid #f3f4f6}.quantity-controls{display:flex;align-items:center;gap:.375rem;background:#f8fafc;padding:.2rem;border-radius:6px;border:1px solid #e5e7eb}.quantity-btn{background:#fff!important;border:1px solid #d1d5db!important;color:#374151!important;padding:.2rem!important;border-radius:4px!important;display:flex!important;align-items:center!important;justify-content:center!important;min-width:24px!important;height:24px!important;cursor:pointer!important;transition:all .2s ease!important;position:relative!important;box-shadow:none!important;text-transform:none!important;letter-spacing:normal!important;font-weight:400!important;margin:0!important}.quantity-btn:before,.quantity-btn:after{display:none!important;content:none!important}.quantity-btn:hover:not(:disabled){background:#f3f4f6!important;border-color:#9ca3af!important;transform:none!important;box-shadow:none!important}.quantity-btn:disabled{opacity:.5!important;cursor:not-allowed!important}.quantity-input{width:45px;text-align:center;padding:.2rem .375rem;border:1px solid #d1d5db;border-radius:4px;background:#fff;font-weight:600;color:#374151;font-size:.9rem}.quantity-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.remove-btn{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.375rem;border-radius:4px;transition:all .2s ease}.remove-btn:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5;transform:scale(1.05)}.totals-section{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e5e7eb;border-radius:8px;padding:.375rem;box-shadow:0 2px 4px -1px #0000001a;height:100%;display:flex;flex-direction:column;overflow:hidden}.total-line-compact{margin-bottom:.25rem}.compact-row{display:flex;justify-content:space-between;align-items:center;padding:.125rem 0;font-size:.8rem;line-height:1.2}.compact-label{color:#6b7280;font-weight:500;flex:1}.compact-value{font-weight:600;color:#374151;text-align:right;flex-shrink:0}.discount-row .compact-value{color:#059669!important}.subtotal-row{border-top:1px solid #f3f4f6;padding-top:.25rem!important;margin-top:.25rem}.subtotal-row .compact-value{color:#374151!important;font-weight:700}.tax-row .compact-value{color:#7c3aed!important}.group-discounts-compact{margin:.25rem 0}.group-header .compact-label{font-weight:600;color:#0369a1}.group-discount-row .compact-label{font-size:.75rem;color:#0369a1}.group-discount-row .compact-value{color:#059669!important}.manual-discount-compact{margin:.25rem 0;padding:.25rem;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.discount-header{margin-bottom:.25rem}.discount-title{font-weight:600;color:#dc3545;font-size:.8rem}.discount-controls-inline{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.discount-input-group{display:flex;align-items:center;gap:.25rem}.discount-input-mini{width:45px;padding:.25rem .375rem;border:1px solid #dee2e6;border-radius:3px;font-size:.75rem;font-weight:500;text-align:center;transition:all .2s ease}.discount-input-mini:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 1px #007bff1a}.discount-unit-mini{font-size:.75rem;font-weight:600;color:#6b7280}.btn-clear-mini{width:20px;height:20px;border:none;background:#dc3545;color:#fff;border-radius:50%;font-size:.7rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-clear-mini:hover{background:#c82333;transform:scale(1.1)}.applied-discounts-compact{margin-top:.25rem}.total-discount-row{border-top:1px solid #e9ecef;padding-top:.25rem!important;margin-top:.25rem}.total-discount-row .compact-value{color:#059669!important}.total-final-compact{background:linear-gradient(135deg,#1f2937,#111827);border-radius:6px;padding:.5rem;margin-top:.375rem;flex-shrink:0}.final-total-row{display:flex;justify-content:space-between;align-items:center}.final-label{color:#fff;font-size:2rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5)}.final-amount{color:#fff!important;font-size:2.5rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.6)}.totals-section{font-size:.8rem;line-height:1.2}.totals-section .total-row{display:flex;justify-content:space-between;align-items:center;padding:.125rem 0;border-bottom:1px solid #f3f4f6;font-size:.8rem}.totals-section .total-row:last-child{border-bottom:none}.totals-section .total-row span:first-child{color:#6b7280;font-weight:500;font-size:.8rem}.totals-section .total-row span:last-child{font-weight:600;color:#374151;font-size:.8rem}.discount-amount{color:#059669!important;font-weight:600!important;font-size:.8rem!important}.subtotal{color:#374151!important;font-weight:600!important;font-size:.8rem!important}.tax{color:#7c3aed!important;font-weight:600!important;font-size:.8rem!important}.total-final{background:linear-gradient(135deg,#1f2937,#111827);color:#fff;padding:.5rem;border-radius:6px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px -1px #1f293766,0 0 0 2px #ffffff1a;min-height:40px;flex-wrap:wrap;gap:.375rem;border:2px solid #374151;flex-shrink:0}.total-final .total-line{display:flex;justify-content:space-between;align-items:center;width:100%;min-height:24px;flex-wrap:wrap;gap:.25rem}.total-final .total-line span{display:block;line-height:1.1;word-break:break-word;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.total-final .total-line span:first-child{font-size:.9rem;font-weight:600;flex:1;min-width:80px;color:#fff}.total-final .total-line span:last-child{font-size:1.1rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.6);flex-shrink:0;text-align:right;min-width:70px;color:#fff}.totals{margin-bottom:.5rem;flex:1;overflow-y:auto;min-height:0}.total-line{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid #f3f4f6}.total-line.total{font-weight:700;font-size:1.1rem;color:#2563eb;border-bottom:none;border-top:1px solid #e5e7eb;margin-top:.25rem;padding-top:.5rem}.group-discounts-section{margin:.5rem 0;padding:.5rem;background:#f0f9ff;border-radius:6px;border-left:4px solid #0ea5e9}.total-line.group-discount{color:#0369a1;font-weight:500;border-bottom:1px solid #e0f2fe;margin:0;padding:.25rem 0}.total-line.group-discount:last-child{border-bottom:none}.total-line.group-discount span:first-child{font-size:.9rem}.total-line.group-discount span:last-child{font-weight:600;color:#0c4a6e}.checkout-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:2px solid #f3f4f6;flex-shrink:0}.checkout-actions .action-buttons{display:flex;gap:.75rem}.checkout-actions .btn{flex:1;padding:.875rem 1.5rem;font-weight:600;font-size:1rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.checkout-actions .btn-secondary{background:#f8fafc;border:2px solid #e5e7eb;color:#6b7280}.checkout-actions .btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#d1d5db;color:#374151;transform:translateY(-1px)}.checkout-actions .btn-large{background:linear-gradient(135deg,#10b981,#059669);border:2px solid #10b981;color:#fff;font-size:1rem;padding:.75rem 1.25rem;box-shadow:0 4px 6px -1px #10b9814d}.checkout-actions .btn-large:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);border-color:#059669;transform:translateY(-2px);box-shadow:0 6px 8px -1px #10b98166}.checkout-actions .btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.25rem .5rem;font-size:.8rem}.btn-large{padding:.75rem 1.5rem;font-size:1rem;flex:1}.icon{width:20px;height:20px}.icon-sm{width:16px;height:16px}.btn.btn-icon{width:30px!important;height:30px!important;min-width:30px!important;padding:0!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;border-radius:6px!important}.btn.btn-icon .icon-sm{width:16px;height:16px;flex-shrink:0}.btn.btn-icon:hover:not(:disabled){transform:scale(1.05)}.cart-items-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;font-size:.85rem;color:#6b7280}.cart-row{padding-inline:1rem}.cart-section .col-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:nowrap;min-width:72px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:1200px;width:95%;height:80vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;display:flex;align-items:center;gap:.5rem;color:#374151}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.modal-close:hover{background:#f3f4f6}.modal-body{padding:1.5rem;flex:1;overflow-y:auto;display:flex;flex-direction:column}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.search-input-container{position:relative;margin-bottom:.75rem}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280;width:20px;height:20px}.search-input{width:100%;padding:.625rem .75rem .625rem 2.5rem;border:2px solid #e5e7eb;border-radius:6px;font-size:1rem}.search-input:focus{outline:none;border-color:#2563eb}.search-loading,.no-results{text-align:center;padding:2rem;color:#6b7280}.search-results{flex:1;overflow-y:auto;min-height:0}.search-result-item{padding:.35rem .75rem;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background-color .15s ease;min-height:48px}.search-result-item:hover,.search-result-item.selected{background:#f1f5f9}.search-result-item.adding{animation:pulse-cart .8s ease-in-out infinite;background:#f0f9ff}@keyframes pulse-cart{0%{box-shadow:inset 0 0 #0ea5e91a}50%{box-shadow:inset 0 0 0 2px #0ea5e933}to{box-shadow:inset 0 0 #0ea5e91a}}.product-info{display:flex;flex-direction:column;justify-content:center;flex:1;min-width:0}.product-info h3{margin:0;color:#1f2937;font-size:.9rem;font-weight:600;line-height:1.2;display:flex;align-items:center;gap:.5rem}.product-details{display:flex;align-items:center;gap:.75rem;margin-top:.15rem;font-size:.8rem;color:#6b7280}.add-to-cart{margin-left:.75rem;display:flex;align-items:center;flex-shrink:0}.btn-add{border:1px solid #e2e8f0;background:#fff;color:#475569;padding:.35rem;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-add:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.btn-add.in-cart{background:#ecfdf5;border-color:#86efac;color:#166534}.btn-add.in-cart:hover{background:#d1fae5;border-color:#4ade80;color:#15803d}.btn-add.adding{background:#eff6ff;border-color:#bfdbfe;color:#2563eb;cursor:wait}.spin{animation:spin .8s linear infinite}.price-loading,.totals-loading{display:inline-flex;align-items:center;gap:4px;color:#6b7280}.syncing-status{display:inline-flex;align-items:center;gap:6px;margin-top:8px;color:#6b7280;font-size:.9rem}.in-cart-badge{margin-left:8px;background:#dcfce7;color:#166534;border:1px solid #86efac;border-radius:999px;padding:2px 8px;font-size:.75rem}.btn-add:disabled{opacity:.6;cursor:not-allowed}.btn-add.in-cart:disabled{background:#dcfce7;border-color:#86efac;color:#166534}.price{font-weight:600;color:#2563eb}.stock{color:#6b7280}.low-stock{color:#f59e0b}.no-stock{color:#ef4444}.payment-modal{max-width:850px;width:95%;max-height:98vh;display:flex;flex-direction:column}.payment-modal .modal-header{padding:.75rem 1rem;flex-shrink:0}.payment-modal .modal-header h2{font-size:1.1rem;margin:0}.payment-modal .modal-body{flex:1;overflow-y:auto;padding:.7rem;display:flex;flex-direction:column;gap:.45rem;min-height:0;max-height:calc(98vh - 160px)}.sale-summary{background:#f9fafb;padding:.5rem .6rem;border-radius:6px;margin-bottom:0}.summary-grid{display:flex;flex-direction:column;gap:.15rem}.summary-line{display:flex;justify-content:space-between;padding:.08rem 0;font-size:.8rem;line-height:1.2}.summary-line.total{font-weight:700;font-size:.9rem;color:#2563eb;border-top:1px solid #e5e7eb;margin-top:.25rem;padding-top:.25rem}.payment-type-section{margin-bottom:0}.payment-type-section h3{margin:0 0 .4rem;color:#374151;font-size:.9rem;font-weight:600}.payment-types{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem}.operation-modes{grid-template-columns:repeat(2,1fr)}.payment-type-btn{padding:.5rem .4rem;border:2px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:all .2s;font-size:.8rem}.payment-type-btn .icon{width:16px;height:16px}.payment-type-btn:hover{border-color:#2563eb}.payment-type-btn.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.amount-section{margin-bottom:0}.amount-section h3{margin:0 0 .4rem;color:#374151;font-size:.9rem;font-weight:600}.amount-input-container{position:relative;margin-bottom:.5rem}.currency{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:#6b7280;font-weight:600;font-size:.85rem}.amount-input{width:100%;padding:.5rem .5rem .5rem 1.6rem;border:2px solid #e5e7eb;border-radius:6px;font-size:.95rem;font-weight:600}.amount-input:focus{outline:none;border-color:#2563eb}.quick-amounts{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.4rem}.quick-amount-btn{padding:.35rem .6rem;border:1px solid #d1d5db;background:#fff;border-radius:4px;cursor:pointer;font-size:.75rem}.quick-amount-btn:hover{background:#f3f4f6}.change-section{background:#f0f9ff;padding:.5rem .6rem;border-radius:6px;border:1px solid #0ea5e9;margin-top:.4rem}.change-line{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.change-amount{font-size:.95rem;font-weight:700;color:#0ea5e9}.change-amount.insufficient{color:#ef4444}.insufficient-warning{color:#ef4444;font-size:.8rem;margin-top:.3rem}.error-message{background:#fef2f2;color:#dc2626;padding:.5rem;border-radius:6px;border:1px solid #fecaca;font-size:.8rem;margin-top:.4rem}.product-create-modal{max-width:500px}.barcode-info{background:#eff6ff;padding:1rem;border-radius:6px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;color:#2563eb}.product-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#374151}.form-input{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem}.form-input:focus{outline:none;border-color:#2563eb}.input-with-prefix,.input-with-suffix{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:12px;color:#6b7280;font-weight:600;z-index:1}.input-with-prefix .form-input{padding-left:2rem}.input-suffix{position:absolute;right:12px;color:#6b7280;font-weight:600}.input-with-suffix .form-input{padding-right:2rem}.form-help{color:#6b7280;font-size:.8rem}.error-message{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:6px;border:1px solid #fecaca;margin-top:1rem}.card-type-section{margin-bottom:0}.card-type-section h3{margin:0 0 .4rem;color:#374151;font-size:.9rem;font-weight:600}.card-types{display:flex;gap:.35rem;flex-wrap:wrap}.card-type-btn{flex:1;min-width:75px;padding:.45rem .6rem;border:2px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer;text-align:center;transition:all .2s;font-size:.8rem}.card-type-btn:hover{border-color:#2563eb}.card-type-btn.active{border-color:#2563eb;background:#eff6ff;color:#2563eb;font-weight:600}.mixed-payment-section{margin-bottom:0;background:#f8fafc;padding:.7rem;border-radius:8px;border:1px solid #e2e8f0}.mixed-payment-section h3{margin:0 0 .5rem;color:#374151;font-size:.9rem;font-weight:600}.cash-amount-section{margin-bottom:.6rem}.cash-amount-section label{display:block;margin-bottom:.35rem;font-weight:500;color:#374151;font-size:.85rem}.card-amount-section{margin-bottom:.5rem}.calculated-amount{display:flex;justify-content:space-between;align-items:center;background:#e0f2fe;padding:.5rem .6rem;border-radius:6px;border:1px solid #0891b2;font-size:.85rem}.calculated-amount .amount{font-size:.95rem;font-weight:700;color:#0891b2}.mixed-payment-warning{background:#fef2f2;color:#dc2626;padding:.5rem;border-radius:6px;border:1px solid #fecaca;font-size:.85rem;margin-top:.5rem}.operation-mode-section{margin-bottom:0}.operation-mode-section h3{margin:0 0 .4rem;color:#374151;font-size:.9rem;font-weight:600}.cc-section{margin-bottom:0;background:#f8fafc;padding:.7rem;border-radius:8px;border:1px solid #e2e8f0}.cc-section h3{margin:0 0 .5rem;color:#374151;font-size:.9rem;font-weight:600}.cc-section .form-row{margin-bottom:.5rem}.cc-section .form-row:last-child{margin-bottom:0}.cc-section label{display:block;margin-bottom:.3rem;font-weight:500;color:#374151;font-size:.85rem}.cc-section .select-input,.cc-section .date-input,.cc-section .text-input{width:100%;padding:.45rem;border:1px solid #d1d5db;border-radius:6px;font-size:.85rem}.cc-section .text-input{resize:vertical;min-height:38px;max-height:60px}.payment-modal .modal-footer{padding:.6rem .75rem;border-top:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.footer-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.footer-actions .btn-compact{padding:.65rem 1.2rem;font-size:.9rem;font-weight:600;border-radius:6px;transition:all .2s;white-space:nowrap;min-width:100px}.footer-actions .btn-secondary.btn-compact{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;flex:0 0 auto}.footer-actions .btn-secondary.btn-compact:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.footer-actions .btn-primary.btn-compact{display:flex;align-items:center;justify-content:center;gap:.4rem;background:#2563eb;color:#fff;border:none;flex:1;min-width:120px}.footer-actions .btn-primary.btn-compact:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px #2563eb4d}.footer-actions .btn-primary.btn-compact:active:not(:disabled){transform:translateY(0)}.footer-actions .btn-primary.btn-compact:disabled{opacity:.6;cursor:not-allowed}.footer-actions .btn-print{background:#059669}.footer-actions .btn-print:hover:not(:disabled){background:#047857;box-shadow:0 4px 6px #0596694d}.footer-actions .btn-primary .icon{width:18px;height:18px;flex-shrink:0}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);position:relative;overflow:hidden}.loading-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse-bg 3s ease-in-out infinite}.loading-content{display:flex;flex-direction:column;align-items:center;gap:24px;z-index:1;position:relative}.modern-spinner{position:relative;width:60px;height:60px}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid transparent;border-top:3px solid #667eea;border-radius:50%;animation:modern-spin 1.2s cubic-bezier(.68,-.55,.265,1.55) infinite}.spinner-ring:before{content:"";position:absolute;top:-3px;left:-3px;width:calc(100% + 6px);height:calc(100% + 6px);border:2px solid transparent;border-top:2px solid rgba(102,126,234,.3);border-radius:50%;animation:modern-spin 2s linear infinite reverse}.loading-text{font-size:16px;font-weight:500;color:#4a5568;margin:0;letter-spacing:.5px;animation:fade-pulse 2s ease-in-out infinite}@keyframes modern-spin{0%{transform:rotate(0);border-top-color:#667eea}25%{border-top-color:#764ba2}50%{transform:rotate(180deg);border-top-color:#667eea}75%{border-top-color:#764ba2}to{transform:rotate(360deg);border-top-color:#667eea}}@keyframes pulse-bg{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}@keyframes fade-pulse{0%,to{opacity:.7}50%{opacity:1}}.access-restricted{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}.access-restricted-content{background:#fff;border-radius:16px;padding:40px;text-align:center;box-shadow:0 10px 30px #0000001a;max-width:500px;width:100%}.access-restricted-content h2{color:#dc3545;margin:0 0 20px;font-size:24px;font-weight:600}.access-restricted-content p{color:#666;margin:0 0 12px;font-size:16px;line-height:1.5}.access-restricted-content p:last-of-type{margin-bottom:30px;font-size:14px;color:#888}.back-to-plans-btn{background:#4285f4;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:500;cursor:pointer;transition:background .3s ease}.back-to-plans-btn:hover{background:#3367d6}@media (max-width: 1024px){.sales-content{grid-template-columns:1fr;gap:1rem}.totals-section{position:static}}@media (max-width: 768px){.sales-toolbar{padding:.75rem 1rem;flex-direction:row;gap:.75rem;flex-wrap:wrap}.sales-toolbar .btn{min-height:44px;padding:.6rem 1rem;font-size:1rem}.nav-buttons{flex-direction:column;width:100%}.nav-btn{width:100%;justify-content:center}.sales-content{padding:1rem;grid-template-columns:1fr;gap:1rem}.cart-section{order:-1;max-height:50vh}.cart-header{padding:1rem}.cart-title{font-size:1.1rem}.cart-summary{font-size:.9rem}.cart-item{padding:1rem}.item-main{flex-direction:column;gap:.75rem}.item-pricing{align-self:flex-start;text-align:left}.product-name{font-size:1rem}.quantity-badge{font-size:.75rem;padding:.2rem .4rem}.item-total-price{font-size:1.1rem}.item-controls{flex-direction:column;gap:.75rem;align-items:stretch}.totals-section{position:static;margin-top:.5rem;padding:1rem}.total-final{padding:.75rem;min-height:50px}.total-final .total-line{min-height:35px;gap:.25rem}.total-final .total-line span:first-child{font-size:.95rem;min-width:100px}.total-final .total-line span:last-child{font-size:1.3rem;min-width:70px}.checkout-actions{flex-direction:column;gap:.75rem}.checkout-actions .btn{padding:.75rem 1rem;font-size:.95rem}.checkout-actions .btn-large{font-size:1.05rem;padding:.9rem 1.2rem;min-height:48px}.payment-types{grid-template-columns:1fr}.modal-content{margin:1rem;max-width:none}.payment-modal{max-width:100%;width:98%;margin:.5rem;max-height:98vh}.payment-modal .modal-body{padding:1rem}.footer-actions{flex-direction:column;gap:.5rem}.footer-actions .btn{width:100%;min-width:auto;padding:.875rem 1rem;font-size:.95rem}.footer-actions .btn-secondary{order:2}.footer-actions .btn-primary{order:1}.keyboard-help{font-size:.8rem;padding:0 .5rem}.total-final{box-shadow:0 6px 12px -2px #1f293780,0 0 0 2px #ffffff26;border:2px solid #4b5563}.total-final .total-line span{text-shadow:0 2px 4px rgba(0,0,0,.3)}}@media (max-width: 480px){.payment-modal{margin:.25rem;width:99%;max-height:99vh}.payment-modal .modal-body{padding:.75rem}.modal-header h2{font-size:1.25rem}.payment-type-btn{padding:.75rem .5rem;font-size:.9rem}.quick-amounts{gap:.25rem}.quick-amount-btn{padding:.4rem .6rem;font-size:.8rem;min-width:60px}.footer-actions .btn{padding:1rem;font-size:1rem;font-weight:600}.footer-actions .btn-primary .icon{width:18px;height:18px}.card-types{gap:.25rem}.card-type-btn{padding:.6rem .4rem;font-size:.85rem}.cart-section{max-height:45vh}.cart-header{padding:.75rem}.cart-title{font-size:1rem}.cart-title .icon{width:18px;height:18px}.cart-summary{font-size:.8rem}.cart-item{padding:.75rem}.product-name{font-size:.95rem}.quantity-badge{font-size:.7rem;padding:.15rem .35rem;min-width:20px}.barcode{font-size:.7rem;padding:1px 4px}.usage-info{font-size:.7rem;padding:2px 6px}.item-total-price{font-size:1rem;padding:.2rem .4rem}.quantity-controls{padding:.2rem;justify-content:center}.quantity-btn{min-width:24px;height:24px;padding:.2rem}.quantity-input{width:40px;padding:.2rem .3rem}.remove-btn{padding:.4rem}.totals-section{padding:.75rem}.totals-header h3{font-size:1rem}.total-final{padding:.6rem;min-height:45px;flex-direction:column;align-items:stretch;text-align:center}.total-final .total-line{flex-direction:column;align-items:center;text-align:center;min-height:auto;gap:.25rem}.total-final .total-line span:first-child{font-size:.9rem;min-width:auto;text-align:center;margin-bottom:.25rem}.total-final .total-line span:last-child{font-size:1.2rem;min-width:auto;text-align:center;font-weight:900}.checkout-actions .btn{padding:.6rem .8rem;font-size:.9rem}.checkout-actions .btn-large{font-size:.95rem;padding:.75rem .8rem}}.cart-item.has-promotion{background-color:#fff8e1;border-left:3px solid #ff9800}.promotion-info{margin-top:4px}.promotion-tag{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:2px 8px;border-radius:12px;font-size:.75em;font-weight:600;box-shadow:0 1px 3px #0003}.price-section{display:flex;flex-direction:column;align-items:center;gap:2px}.price-section .original-price{text-decoration:line-through;color:#999;font-size:.8em;font-weight:500}.price-input.discounted{color:#e91e63;font-weight:600}.total-line.original{color:#999;font-size:.9em}.total-line.discount{color:#4caf50;font-weight:600}.total-line.discount span:last-child{color:#4caf50}.group-promotion-info{margin-top:4px}.group-promotion-tag{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;padding:2px 8px;border-radius:12px;font-size:.75em;font-weight:600;box-shadow:0 1px 3px #0003;display:inline-flex;align-items:center;gap:4px}.manual-discount-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.5rem;margin:.375rem 0}.discount-controls-row{display:flex;gap:.75rem;margin-bottom:.375rem}.discount-control-group{flex:1}.discount-controls{display:flex;align-items:center;gap:.375rem;margin-bottom:.375rem}.discount-input{padding:.375rem .5rem;border:1px solid #dee2e6;border-radius:3px;font-size:.85rem;font-weight:500;text-align:center;transition:all .2s ease;width:70px;flex-shrink:0}.discount-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.discount-unit{font-weight:600;color:#6c757d;font-size:.9rem;min-width:20px}.total-line.percentage-discount,.total-line.fixed-discount,.total-line.total-manual-discount{font-size:.9rem;padding:.25rem 0}.total-line.total-manual-discount{font-weight:700;border-top:1px solid #e9ecef;margin-top:.5rem;padding-top:.5rem}.clear-all-discounts{margin-top:.5rem;text-align:center}.clear-all-discounts .btn{font-size:.8rem;padding:.4rem .8rem}.manual-discount-controls{display:flex;flex-direction:column;gap:.5rem}.discount-type-selector{display:flex;gap:.5rem}.discount-type-selector .btn{flex:1;padding:.5rem .75rem;border-radius:4px;border:1px solid #dee2e6;background:#fff;color:#6c757d;font-weight:500;font-size:.85rem;transition:all .2s ease;cursor:pointer}.discount-type-selector .btn.btn-primary{background:#007bff;border-color:#007bff;color:#fff}.discount-type-selector .btn.btn-secondary{background:#fff;border-color:#dee2e6;color:#6c757d}.discount-type-selector .btn:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000001a}.discount-input{padding:10px 12px;border:2px solid #dee2e6;border-radius:6px;font-size:16px;font-weight:500;text-align:center;transition:all .2s ease}.discount-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.btn-clear-discount{background:#dc3545;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;font-weight:500;font-size:.8rem;cursor:pointer;transition:all .2s ease}.btn-clear-discount:hover{background:#c82333;transform:translateY(-1px)}.total-line.manual-discount{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:.5rem .75rem;border-radius:4px;margin:.5rem 0;font-weight:600;font-size:.9rem}.total-line.manual-discount .discount-amount{color:#fff;font-weight:700}.sale-summary .summary-line.discount{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:8px 12px;border-radius:6px;margin:4px 0}.sale-summary .summary-line.discount .discount-amount{color:#fff;font-weight:700}@media (max-width: 768px){.manual-discount-section{padding:.5rem;margin:.25rem 0}.discount-type-selector{flex-direction:column}.discount-type-selector .btn{padding:.6rem .75rem}.discount-input{font-size:1rem;padding:.6rem .75rem}}.app-preloader{position:fixed;inset:0;background:#fff;display:flex;align-items:center;justify-content:center;z-index:9999;opacity:1;transition:opacity .3s ease}.app-preloader.fade-out{opacity:0}.preloader-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;text-align:center}.preloader-brand{font-size:18px;font-weight:600;color:#1f2937;text-align:center}.preloader-ring{width:48px;height:48px;border-radius:50%;border:4px solid #e5e7eb;border-top-color:#2563eb;animation:preloader-spin .8s linear infinite}@keyframes preloader-spin{to{transform:rotate(360deg)}}.product-info{display:grid!important;grid-template-columns:1fr auto!important;grid-template-rows:auto auto!important;column-gap:1rem!important;row-gap:.25rem!important;flex:1!important;min-width:0!important}.product-info h3{grid-column:1!important;grid-row:1!important;margin:0!important;color:#1f2937!important;font-size:1rem!important;font-weight:600!important;line-height:1.2!important;display:flex!important;align-items:center!important;gap:.5rem!important}.product-meta{grid-column:1!important;grid-row:2!important;display:flex!important;align-items:center!important;gap:.5rem!important}.product-details{grid-column:2!important;grid-row:1 / -1!important;align-self:center!important;justify-self:end!important;display:flex!important;align-items:center!important;gap:.75rem!important;font-size:.9rem!important;color:#6b7280!important;margin-top:0!important}@keyframes logo-pulse{0%{transform:scale(1);box-shadow:0 0 #07d97766}70%{transform:scale(1.05);box-shadow:0 0 0 15px #07d97700}to{transform:scale(1);box-shadow:0 0 #07d97700}}.logo-pulse{animation:logo-pulse 2s infinite}.cart-grid-header,.cart-grid-row{display:grid;grid-template-columns:2fr .9fr .9fr .9fr .9fr .9fr .9fr;gap:8px;align-items:center;padding:.5rem 1rem}.cart-grid-header{font-weight:600;text-align:right}.cart-grid-header .col-product,.cart-grid-row .col-product{text-align:left;overflow:hidden}.cart-grid-header .col-qty,.cart-grid-row .col-qty{text-align:center;display:flex;justify-content:center}.cart-grid-header .col-cost,.cart-grid-header .col-subtotal,.cart-grid-header .col-discount,.cart-grid-header .col-total,.cart-grid-header .col-actions,.cart-grid-row .col-cost,.cart-grid-row .col-subtotal,.cart-grid-row .col-discount,.cart-grid-row .col-total{text-align:right}.product-name{margin:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;font-weight:600;color:#1f2937}.cart-grid-row .col-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:nowrap}.item-details-expanded{grid-column:1 / -1;margin-top:.5rem}@media (max-width: 768px){.cart-grid-header{display:none}.cart-grid-row{display:flex;flex-wrap:wrap;padding:1rem;gap:.5rem;position:relative;align-items:center}.col-product{width:100%;margin-bottom:.5rem}.product-name{white-space:normal;font-size:1rem;line-height:1.3}.col-qty{order:2;flex:0 0 auto;width:auto;justify-content:flex-start}.col-cost,.col-subtotal,.col-discount{display:none}.col-total{order:3;flex:1;text-align:right;font-weight:700;font-size:1.1rem;color:#2563eb;display:flex;align-items:center;justify-content:flex-end}.col-total:before{content:"Total: ";color:#6b7280;font-weight:500;font-size:.9rem;margin-right:.5rem}.col-actions{order:4;width:100%;justify-content:flex-end;margin-top:.5rem;border-top:1px solid #f3f4f6;padding-top:.75rem;gap:12px}.col-actions .btn-icon{width:40px!important;height:40px!important}.col-actions .icon-sm{width:20px;height:20px}}@media (max-width: 480px){.cart-grid-row{padding:.75rem}.col-total{font-size:1rem}}.cart-row.cart-grid-row{padding:0!important}.cart-grid-header{padding:.625rem 1rem}@media (max-width: 768px){.cart-row.cart-grid-row{padding:0!important}}@media (max-width: 768px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{width:100%;height:100%;max-height:100vh;border-radius:0;margin:0;display:flex;flex-direction:column}.modal-header{padding:1rem;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:1.1rem}.modal-body{padding:.5rem}.search-input-container{margin-bottom:.5rem;position:sticky;top:0;background:#fff;z-index:5;padding-bottom:.5rem}.search-input{padding:.75rem 1rem .75rem 2.5rem;font-size:1rem}.search-icon{width:24px;height:24px;left:10px}.search-result-item{padding:.75rem .5rem;min-height:60px;align-items:flex-start}.product-info{display:flex!important;flex-direction:column!important;gap:4px!important}.product-info h3{grid-column:auto!important;grid-row:auto!important;font-size:1rem!important;margin-bottom:2px!important;white-space:normal!important}.product-meta{grid-column:auto!important;grid-row:auto!important;font-size:.85rem!important;color:#6b7280;flex-wrap:wrap}.product-details{grid-column:auto!important;grid-row:auto!important;justify-self:flex-start!important;margin-top:4px!important}.product-details .price{font-size:1.1rem;font-weight:700;color:#2563eb}.add-to-cart{align-self:center;margin-left:.5rem}.btn-add{width:44px;height:44px;padding:0}.btn-add .icon{width:24px;height:24px}.modal-footer{padding:.75rem}.keyboard-help{display:none}}@media (max-width: 768px){.sales-screen{width:100vw;overflow-x:hidden}.sales-content{padding:.5rem;gap:.5rem;width:100%}.cart-section{border-radius:8px;border:none;box-shadow:0 2px 4px #0000000d}.cart-item{padding:.75rem;margin-bottom:.5rem;border:1px solid #f3f4f6;border-radius:8px;background:#fff;box-shadow:0 1px 2px #00000005}.cart-item:last-child{margin-bottom:.5rem;border-bottom:1px solid #f3f4f6}.cart-grid-row{padding:0!important;gap:.5rem;display:grid;grid-template-columns:1fr auto;grid-template-areas:"name total" "qty actions";align-items:center}.col-product{grid-area:name;width:100%;margin-bottom:0}.product-name{font-size:1rem;line-height:1.3;white-space:normal}.col-total{grid-area:total;text-align:right;justify-content:flex-end;font-size:1.1rem;order:unset;flex:unset}.col-total:before{display:none}.col-qty{grid-area:qty;justify-content:flex-start;order:unset;flex:unset;margin-top:.5rem}.col-actions{grid-area:actions;justify-content:flex-end;margin-top:.5rem;border-top:none;padding-top:0;gap:8px;width:auto;order:unset}.col-actions .btn-icon{width:36px!important;height:36px!important;background:#f3f4f6;border:1px solid #e5e7eb}.col-cost,.col-subtotal,.col-discount{display:none!important}}@media (max-width: 380px){.cart-grid-row{grid-template-columns:1fr;grid-template-areas:"name" "total" "qty" "actions";gap:.25rem}.col-total{text-align:left;justify-content:flex-start;font-weight:700;color:#2563eb}.col-actions{justify-content:space-between;width:100%;margin-top:.5rem}}@media (max-width: 768px){.app-nav{display:flex!important;justify-content:space-between;align-items:center;padding:0 .75rem!important;min-height:56px!important;height:auto;gap:8px!important;grid-template-columns:none!important}.nav-left{flex:0 0 auto;min-width:40px;margin-right:0}.drawer-toggle-btn{min-width:40px!important;width:40px;height:40px;padding:0!important;justify-content:center;background:transparent!important;border:none!important}.drawer-toggle-btn:active{background:#ffffff1a!important}.drawer-toggle-text{display:none}.nav-brand{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;line-height:1.1;white-space:nowrap;overflow:hidden;text-align:center;padding:0 4px}.nav-brand>div:first-child{font-size:1rem!important;margin-bottom:0!important;max-width:100%;overflow:hidden;text-overflow:ellipsis}.current-screen-indicator{font-size:.75rem!important;margin-top:2px!important;opacity:.9;max-width:100%}.nav-right{display:flex!important;flex:0 0 auto;gap:8px!important;min-width:40px;justify-content:flex-end}.nav-right>div:first-child{display:none!important}.nav-right img{height:36px!important;width:36px!important;padding:2px!important;box-shadow:none!important}}@media (max-width: 480px){.navigation-drawer{width:85%!important;max-width:300px}.nav-brand>div:first-child{font-size:.9rem!important}}.drawer-toggle-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:12px 16px;border-radius:8px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-weight:500;gap:8px;min-width:80px}.drawer-toggle-text{font-size:.9rem;font-weight:500}.drawer-toggle-btn:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 8px #0003}.drawer-toggle-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}.navigation-drawer{position:fixed;top:0;left:-320px;width:320px;height:100vh;background:#fff;color:#1f2937;z-index:1000;transition:left .3s ease;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a}.navigation-drawer.open{left:0}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#042959}.user-info{display:flex;align-items:center;gap:12px;padding:1.5rem;border-bottom:1px solid #f3f4f6;background:#f9fafb}.user-avatar{width:40px;height:40px;background:#042959;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.1rem;box-shadow:0 4px 10px #04295933}.drawer-nav{flex:1;overflow-y:auto;padding:1rem 0}.nav-item{width:100%;background:none;border:none;color:#4b5563;cursor:pointer;padding:1rem 1.5rem;text-align:left;display:flex;align-items:center;gap:12px;transition:all .2s ease;border-radius:0;font-size:.95rem;font-weight:500;border-left:3px solid transparent}.nav-item:hover{background:#f3f4f6;color:#042959}.nav-item.active{background:#0429590d;color:#042959;border-left:3px solid #042959;font-weight:600}.nav-item.active:hover{background:#0429591a}.nav-list{list-style:none;margin:0;padding:0}.nav-icon{flex-shrink:0}.nav-label{flex:1}.drawer-close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:6px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.drawer-close-btn:hover{background:#f3f4f6;color:#ef4444}.user-details{flex:1;display:flex;flex-direction:column;gap:2px}.user-name{font-weight:600;color:#111827;font-size:.95rem}.user-email{font-size:.8rem;color:#6b7280}.drawer-footer{padding:1rem 1.5rem;border-top:1px solid #f3f4f6;background:#fff;text-align:center;display:flex;flex-direction:column;gap:1rem}.logout-btn{background:#e74c3c;border:none;color:#fff;padding:.75rem 1rem;border-radius:6px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.9rem;font-weight:500;width:100%}.logout-btn:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 2px 8px #e74c3c4d}.logout-btn:active{transform:translateY(0);box-shadow:0 1px 4px #e74c3c4d}.logout-icon{transition:transform .3s ease}.logout-btn:hover .logout-icon{transform:rotate(-10deg)}.drawer-version{font-size:.8rem;color:#95a5a6}@media (max-width: 768px){.navigation-drawer{width:100%;left:-100%}.navigation-drawer.open{left:0}.drawer-header{padding:1rem}.drawer-brand h2{font-size:1.1rem}.drawer-user-info{padding:1rem}.nav-item{padding:.875rem 1rem;font-size:.9rem}}@media (max-width: 480px){.navigation-drawer{width:100%}.drawer-header,.drawer-user-info{padding:.875rem}.nav-item{padding:.75rem .875rem}}.drawer-nav::-webkit-scrollbar{width:6px}.drawer-nav::-webkit-scrollbar-track{background:#34495e}.drawer-nav::-webkit-scrollbar-thumb{background:#7f8c8d;border-radius:3px}.drawer-nav::-webkit-scrollbar-thumb:hover{background:#95a5a6}.products-screen{padding:20px;max-width:1200px;margin:0 auto}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.products-header h1{display:flex;align-items:center;gap:12px;color:#2c3e50;margin:0;font-size:2rem;font-weight:600}.products-header h1 .icon{width:32px;height:32px;color:#3498db}.products-search{margin-bottom:25px}.search-input{position:relative;max-width:400px}.search-input .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#7f8c8d}.search-input input{width:100%;padding:12px 12px 12px 45px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s ease}.search-input input:focus{outline:none;border-color:#3498db}.products-table-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden;margin-top:20px}.table-responsive{overflow-x:auto;max-height:600px;overflow-y:auto}.products-table{width:100%;min-width:850px;border-collapse:collapse;font-size:14px;table-layout:fixed;box-sizing:border-box}.products-table th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;padding:10px 6px;text-align:left;position:sticky;top:0;z-index:10;border:none;font-size:11px;text-transform:uppercase;letter-spacing:.2px;box-sizing:border-box;vertical-align:middle}.products-table td{padding:6px 4px;border-bottom:1px solid #e9ecef;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;position:relative}.products-table tbody tr{transition:all .2s ease;border-left:3px solid transparent}.products-table tbody tr:hover{background-color:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.products-table tbody tr.low-stock{background-color:#fff5f5;border-left-color:#e53e3e}.products-table tbody tr.low-stock:hover{background-color:#fed7d7}.products-table tbody tr:last-child td{border-bottom:none}.products-table tbody tr:nth-child(2n){background-color:#fafbfc}.products-table tbody tr:nth-child(2n):hover{background-color:#f8f9fa}.unit-quantity{font-size:11px;color:#6c757d;font-weight:500;background:#f8f9fa;padding:3px 6px;border-radius:10px;display:inline-block}.table-responsive::-webkit-scrollbar{width:8px;height:8px}.table-responsive::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.table-responsive::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}.table-responsive::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.products-table th.type-column,.products-table td.type-column{width:120px!important;min-width:120px!important;max-width:120px!important;text-align:center!important;padding:6px 4px!important;box-sizing:border-box!important}.products-table th.name-column,.products-table td.name-column{width:35%!important;min-width:250px!important;box-sizing:border-box!important}.products-table td.name-column{white-space:normal;word-wrap:break-word;padding:8px 6px!important}.products-table th.price-column,.products-table td.price-column{width:130px!important;min-width:130px!important;max-width:130px!important;text-align:right!important;font-weight:600;padding:6px 10px 6px 4px!important;box-sizing:border-box!important}.products-table th.stock-column,.products-table td.stock-column{width:150px!important;min-width:150px!important;max-width:150px!important;text-align:center!important;padding:6px 8px!important;box-sizing:border-box!important}.products-table th.unit-quantity-column,.products-table td.unit-quantity-column{width:130px!important;min-width:130px!important;max-width:130px!important;text-align:center!important;padding:6px 8px!important;box-sizing:border-box!important}.products-table th.actions-column,.products-table td.actions-column{width:120px!important;min-width:120px!important;max-width:120px!important;text-align:center!important;padding:4px 2px!important;box-sizing:border-box!important}.product-code{font-size:.75em;color:#666;font-family:monospace;margin-top:2px}.parent-product{font-size:.75em;color:#666;margin-top:2px;font-style:italic}.volume-info,.availability-info{display:flex;flex-direction:column;align-items:center;gap:2px}@media (max-width: 768px){.products-table-container{border-radius:8px;margin-top:15px}.products-table th,.products-table td{padding:10px 8px;font-size:13px}.products-table .type-column{width:100px}.products-table .name-column{min-width:200px}.products-table .price-column{width:100px}.products-table .stock-column{width:120px}.products-table .unit-quantity-column{width:100px}.products-table .actions-column{width:90px}.product-type{font-size:10px;padding:4px 8px}.product-type .icon{width:12px;height:12px}.stock,.stock-amount,.status{font-size:11px;padding:4px 8px;min-width:50px}.btn-small{padding:6px 8px;font-size:11px}.btn-small .icon{width:12px;height:12px}}.stock{padding:4px 8px;border-radius:15px;font-size:11px;font-weight:600;text-align:center;min-width:50px;display:inline-block;white-space:nowrap;box-shadow:0 1px 3px #0000001a;text-transform:uppercase;letter-spacing:.3px}.stock.low{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.stock.medium{background:linear-gradient(135deg,#feca57,#ff9ff3);color:#fff}.stock.high{background:linear-gradient(135deg,#48dbfb,#0abde3);color:#fff}.stock-amount{padding:4px 8px;border-radius:15px;font-size:11px;font-weight:600;text-align:center;min-width:50px;display:inline-block;white-space:nowrap;box-shadow:0 1px 3px #0000001a;text-transform:uppercase;letter-spacing:.3px}.stock-amount.low{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.stock-amount.normal{background:linear-gradient(135deg,#48dbfb,#0abde3);color:#fff}.status{padding:4px 8px;border-radius:15px;font-size:11px;font-weight:600;text-align:center;min-width:50px;display:inline-block;white-space:nowrap;box-shadow:0 1px 3px #0000001a;text-transform:uppercase;letter-spacing:.3px}.status.available{background:linear-gradient(135deg,#48dbfb,#0abde3);color:#fff}.status.insufficient{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.supplier-info{color:#495057;font-size:.9em;cursor:help}.supplier-info:hover{color:#007bff;text-decoration:underline}.no-supplier{color:#6c757d;font-style:italic;font-size:.9em}.actions{display:flex;gap:3px;justify-content:center;flex-wrap:nowrap;min-width:0;width:100%}.btn-small{padding:3px 5px;font-size:9px;min-width:0;border-radius:4px;white-space:nowrap;border:none;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:1px;font-weight:600;text-transform:uppercase;letter-spacing:.1px;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.btn-small:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.btn-small.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-small.btn-danger{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.btn-small .icon{width:8px;height:8px}.products-table .product-code{font-family:Courier New,monospace;font-size:10px;color:#6c757d;margin-top:2px;background:#f8f9fa;padding:1px 4px;border-radius:3px;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis}.products-table .supplier-info{font-size:10px;color:#6c757d;margin-top:2px;font-style:italic;max-width:100%;overflow:hidden;text-overflow:ellipsis}.products-table .parent-product{font-size:10px;color:#6c757d;margin-top:2px;font-style:italic;background:#e3f2fd;padding:1px 4px;border-radius:3px;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis}.products-table .volume-info,.products-table .stock-info,.products-table .availability-info{display:flex;flex-direction:column;gap:4px;align-items:center}.products-table .volume-info small,.products-table .stock-info small,.products-table .availability-info small{font-size:10px;color:#6c757d;background:#f8f9fa;padding:1px 4px;border-radius:3px}.empty-state{text-align:center;padding:60px 20px;color:#7f8c8d}.empty-state .icon{width:64px;height:64px;margin-bottom:16px;color:#bdc3c7}.empty-state p{font-size:18px;margin-bottom:20px}.modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;width:95%;max-width:700px;max-height:85vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.close-btn{background:none;border:none;font-size:24px;color:#7f8c8d;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.close-btn:hover{background-color:#f0f0f0}.product-form{padding:24px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#2c3e50}.form-group input,.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.notification{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:500}.notification.success{background-color:#c6f6d5;color:#2f855a;border:1px solid #9ae6b4}.notification.error{background-color:#fed7d7;color:#c53030;border:1px solid #feb2b2}.notification .icon{width:20px;height:20px}.volume-info{display:flex;flex-direction:row;gap:6px;align-items:center;flex-wrap:wrap}.volume-info small{color:#666;font-size:.75em}.liquid-specific,.subproduct-specific,.availability-info{display:flex;flex-direction:row;gap:6px;align-items:center;flex-wrap:wrap}.availability-info small{color:#666;font-size:.75em}.parent-product,.volume-used,.min-stock{font-size:.75em;color:#666;white-space:nowrap}.status{display:inline-block;margin-right:0;font-size:.8em;padding:2px 6px;border-radius:6px;font-weight:600}.status.available{background-color:#c6f6d5;color:#2f855a}.status.insufficient{background-color:#fed7d7;color:#c53030}.product-type{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:4px 8px;border-radius:15px;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;box-shadow:0 1px 3px #0000001a}.product-type.normal{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.product-type.liquid{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.product-type.weight{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.product-type.subproduct{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.product-type .icon{width:12px;height:12px}@media (max-width: 768px){.products-screen{padding:15px}.products-header{flex-direction:column;gap:15px;align-items:stretch}.products-header h1{font-size:1.5rem}.products-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.product-type{font-size:.7em;padding:2px 4px}.parent-product,.volume-used,.min-stock,.volume-info small{font-size:.7em}.form-row{grid-template-columns:1fr}.modal{margin:10px;max-width:none}.form-actions{flex-direction:column}}@media (max-width: 480px){.products-table th,.products-table td{padding:8px 6px;font-size:12px}.products-table .type-column{width:80px}.products-table .name-column{min-width:150px}.products-table .price-column{width:80px}.products-table .stock-column{width:100px}.products-table .unit-quantity-column,.products-table .actions-column{width:80px}.actions{flex-direction:column;gap:4px}.btn-small{width:100%;justify-content:center;padding:6px 8px;font-size:10px}.btn-small .icon{width:12px;height:12px}.product-type{font-size:9px;padding:3px 6px}.product-type .icon{width:10px;height:10px}.stock,.stock-amount,.status{font-size:10px;padding:3px 6px;min-width:40px}.products-table .product-code,.products-table .supplier-info,.products-table .parent-product{font-size:10px}.products-table .volume-info small,.products-table .stock-info small,.products-table .availability-info small{font-size:9px}}.has-promotion{background-color:#fff8e1;border-left:3px solid #ff9800}.price-container{display:flex;flex-direction:row;gap:8px;align-items:center}.original-price{font-weight:600;color:#333}.has-promotion .original-price{text-decoration:line-through;color:#999;font-size:.9em}.discounted-price{color:#e91e63;font-weight:700;font-size:1.1em}.promotions-cell{min-width:100px;max-width:150px}.active-promotions{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.promotion-tag{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:2px 6px;border-radius:12px;font-size:.75em;font-weight:600;cursor:help;box-shadow:0 1px 3px #0003}.more-promotions{background:#666;color:#fff;padding:2px 6px;border-radius:12px;font-size:.7em;font-weight:500}.no-promotions{color:#999;font-style:italic;font-size:.9em}.sales-history-screen{padding:20px;max-width:1400px;margin:0 auto;width:100%}@media print{body *{visibility:hidden}.print-ticket,.print-ticket *{visibility:visible}.print-ticket{position:absolute;left:0;top:0;width:80mm;margin:0;padding:5mm}}.print-ticket{width:80mm;padding:10mm;font-family:Courier New,monospace;background-color:#fff;color:#000;box-sizing:border-box}.ticket-content{width:100%}.ticket-header{text-align:center;margin-bottom:10px}.ticket-header h2{font-size:16px;margin:0 0 5px}.ticket-header p{font-size:12px;margin:2px 0}.ticket-items{margin:15px 0}.ticket-items h3{font-size:14px;margin:0 0 5px;border-bottom:1px dashed #000;padding-bottom:3px}.ticket-items-table{width:100%;border-collapse:collapse;font-size:10px}.ticket-items-table th{text-align:left;font-weight:700;padding:3px 0}.ticket-items-table td{padding:3px 0}.ticket-promotions{margin:10px 0;font-size:10px}.ticket-promotions h3{font-size:12px;margin:0 0 5px;border-bottom:1px dashed #000;padding-bottom:3px}.ticket-promotions ul{list-style-type:none;padding:0;margin:0}.ticket-promotions li{padding:2px 0}.ticket-totals{margin:15px 0;font-size:12px}.total-line{display:flex;justify-content:space-between;margin:3px 0}.final-total{font-weight:700;border-top:1px dashed #000;padding-top:3px;margin-top:5px}.ticket-payment{margin:15px 0;font-size:10px}.ticket-payment h3{font-size:12px;margin:0 0 5px;border-bottom:1px dashed #000;padding-bottom:3px}.ticket-payment p{margin:2px 0}.ticket-footer{text-align:center;margin-top:15px;font-size:12px;border-top:1px dashed #000;padding-top:5px}@media print{body *{visibility:hidden}.print-ticket,.print-ticket *{visibility:visible}.print-ticket{position:absolute;left:0;top:0;width:80mm;padding:0;margin:0}}.screen-header{margin-bottom:32px}.filters-container{background:#fff;border-radius:12px;border:2px solid #e1e8ed;box-shadow:0 2px 8px #00000014;overflow:hidden;width:100%}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#042959;border-bottom:2px solid rgba(255,255,255,.1)}.filters-title{margin:0;color:#fff;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.filters-content{padding:20px 24px;display:flex;gap:24px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:8px;flex:0 0 auto}.filter-group:nth-child(1){min-width:320px}.filter-group:nth-child(2){flex:1 1 400px;min-width:400px}.filter-group:nth-child(3){min-width:220px}.filter-label{font-size:12px;font-weight:600;color:#6b7280;margin:0;text-transform:uppercase;letter-spacing:.5px;height:16px}.filter-type-selector{display:flex;gap:10px;flex-wrap:nowrap}.filter-option{flex:1 1 0;min-width:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;height:42px;background:#f8f9fa;border:2px solid #e1e8ed;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;color:#2c3e50;font-weight:500;white-space:nowrap;box-sizing:border-box}.filter-option:hover{background:#e8f4fd;border-color:#042959;transform:translateY(-1px)}.filter-option.active{background:#042959;border-color:#042959;color:#fff;box-shadow:0 4px 12px #0429594d}.filter-option input[type=radio]{margin:0;cursor:pointer;accent-color:#042959}.filter-option.active input[type=radio]{accent-color:white}.date-range-inputs{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;width:100%}.date-input-wrapper{flex:0 0 auto;width:160px;display:flex;flex-direction:column;gap:4px}.date-label{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;height:16px}.date-input{width:100%;padding:10px 12px;height:42px;border:2px solid #e1e8ed;border-radius:8px;font-size:13px;color:#2c3e50;background:#fff;transition:all .2s ease;font-family:inherit;box-sizing:border-box}.date-input:focus{outline:none;border-color:#042959;box-shadow:0 0 0 3px #0429591a}.date-separator{font-size:16px;color:#042959;font-weight:600;align-self:flex-end;padding-bottom:10px;flex-shrink:0;margin:0 4px;height:42px;display:flex;align-items:center}.vendor-select{width:100%;min-width:220px;padding:10px 12px;height:42px;border:2px solid #e1e8ed;border-radius:8px;font-size:14px;color:#2c3e50;background:#fff;cursor:pointer;transition:all .2s ease;font-family:inherit;box-sizing:border-box}.vendor-select:focus{outline:none;border-color:#042959;box-shadow:0 0 0 3px #0429591a}.vendor-select:hover{border-color:#042959}.date-range-error{margin-top:8px;padding:10px 14px;background:#fef3c7;border:2px solid #f59e0b;border-radius:8px;color:#92400e;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.export-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:2px solid transparent;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #10b9814d}.export-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.export-btn:disabled{opacity:.6;cursor:not-allowed}.export-btn .w-4{width:16px;height:16px}.header-top{display:flex;justify-content:space-between;align-items:center;gap:12px}.header-filters{display:grid;grid-template-columns:1fr 1.2fr .8fr;gap:12px;align-items:center}.date-input-group{display:flex;align-items:center;gap:8px;background:#fff;padding:8px 10px;border-radius:8px;border:1px solid #e1e8ed}.date-input-group span{color:#7f8c8d;font-size:14px}.spinner,.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#6b7280}.loading-state p{margin-top:16px;font-size:14px;font-weight:500;color:#042959}.sales-history-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#042959;border-radius:50%;animation:spin .8s linear infinite}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.metric-card{background:#fff;padding:20px;border-radius:12px;border:2px solid #e1e8ed;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:15px;transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.metric-icon{background:#3498db;color:#fff;padding:12px;border-radius:8px;display:flex;align-items:center;justify-content:center}.metric-content h3{margin:0 0 5px;font-size:14px;color:#7f8c8d;font-weight:500}.metric-value{font-size:24px;font-weight:700;color:#2c3e50;margin:0}.payment-breakdown{flex-direction:column;align-items:flex-start}.payment-breakdown h3{margin-bottom:15px;font-size:16px;color:#2c3e50}.payment-breakdown-section{margin-top:20px}.payment-breakdown-section .metric-card{width:100%}.payment-items{display:flex;flex-direction:row;gap:24px;width:100%;flex-wrap:wrap}.payment-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#2c3e50;flex:1 1 auto;min-width:200px}.daily-sales-section{margin-bottom:30px}.daily-sales-section h3{margin-bottom:15px;color:#2c3e50;font-size:20px;font-weight:600}.daily-sales-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.daily-sale-card{background:#fff;padding:15px;border-radius:8px;border:2px solid #e1e8ed;box-shadow:0 2px 4px #0000001a;transition:transform .2s}.action-buttons{display:flex;gap:8px}.action-btn{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:6px;border-radius:4px;transition:background-color .2s}.view-btn:hover{background-color:#3498db1a;color:#3498db}.print-btn:hover{background-color:#2ecc711a;color:#2ecc71}.modal-actions{display:flex;align-items:center;gap:10px}.modal-actions .print-btn{display:flex;align-items:center;gap:5px;background-color:#2ecc71;color:#fff;border:none;border-radius:4px;padding:6px 12px;font-size:14px;cursor:pointer;transition:background-color .2s}.modal-actions .print-btn:hover{background-color:#27ae60}.daily-sale-card:hover{transform:translateY(-1px)}.daily-date{font-weight:600;color:#2c3e50;margin-bottom:8px;font-size:14px}.daily-stats{display:flex;flex-direction:column;gap:4px}.daily-count{font-size:12px;color:#7f8c8d}.daily-revenue{font-size:16px;font-weight:600;color:#27ae60}.sales-list-section{margin-bottom:30px}.sales-list-section h3{margin-bottom:15px;color:#2c3e50;font-size:20px;font-weight:600}.empty-state{text-align:center;padding:40px 20px;color:#7f8c8d;background:#fff;border-radius:8px;border:2px solid #e1e8ed}.sales-table{background:#fff;border-radius:8px;border:2px solid #e1e8ed;overflow:hidden;box-shadow:0 2px 4px #0000001a;width:100%}.table-header{display:grid;grid-template-columns:minmax(0,.6fr) minmax(0,1.2fr) minmax(0,1fr) minmax(0,.7fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr) minmax(0,.6fr);background:#f8f9fa;padding:15px 10px;font-weight:600;color:#2c3e50;border-bottom:2px solid #e1e8ed;font-size:13px;text-align:center;align-items:center}.table-header>div{display:flex;justify-content:center;align-items:center;text-align:center;padding:0 4px}.table-body{max-height:none!important;overflow-y:visible!important;height:auto!important}.table-row{display:grid;grid-template-columns:minmax(0,.6fr) minmax(0,1.2fr) minmax(0,1fr) minmax(0,.7fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr) minmax(0,.6fr);padding:12px 10px;border-bottom:1px solid #e1e8ed;align-items:center;transition:background-color .2s;position:relative}.table-row>div{display:flex;justify-content:center;align-items:center;text-align:center;padding:0 4px;overflow-wrap:break-word}.table-row>div{display:flex;justify-content:center;align-items:center;text-align:center;padding:0 4px}.table-row:hover{background-color:#f8f9fa}.table-row:last-child{border-bottom:none}.col-id{font-weight:600;color:#3498db}.col-date{font-size:13px;color:#2c3e50}.col-items{font-size:13px;color:#7f8c8d}.payment-type{display:flex;align-items:center;gap:6px;font-size:13px;color:#2c3e50}.payment-details{display:flex;flex-direction:column;gap:.25rem}.payment-main{font-weight:500}.payment-breakdown{display:flex;gap:.5rem}.payment-breakdown small{color:#666;font-size:.75rem;background:#f0f0f0;padding:.125rem .25rem;border-radius:.25rem}.card-type{color:#666;font-size:.75rem;text-transform:capitalize}.card-type-detail{color:#666;font-size:.875rem;text-transform:capitalize}.col-total{font-weight:600;color:#27ae60}.col-vendor{font-size:13px;color:#2c3e50;font-weight:500}.col-subtotal{font-size:13px;color:#2c3e50}.col-tax{font-size:13px;color:#e67e22}.col-discount{font-size:13px;color:#e74c3c;font-weight:500}.col-received{font-size:13px;color:#27ae60}.col-change{font-size:13px;color:#f39c12}.action-btn{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.view-btn{color:#3498db}.view-btn:hover{background-color:#e3f2fd}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:1000px;width:95%;max-height:85vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:2px solid #e1e8ed}.modal-header h3{margin:0;color:#2c3e50;font-size:20px;font-weight:600}.close-btn{background:none;border:none;font-size:24px;color:#7f8c8d;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:#f8f9fa;color:#2c3e50}.modal-body{padding:25px;width:100%;box-sizing:border-box}.sale-info{margin-bottom:25px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f1f2f6}.info-row:last-child{border-bottom:none}.label{font-weight:600;color:#2c3e50}.sale-id{font-weight:700;color:#3498db;font-size:16px}.vendor-name{font-weight:600;color:#2c3e50;background:#e8f4fd;padding:4px 8px;border-radius:4px}.amount-received{font-weight:600;color:#27ae60}.change-amount{font-weight:600;color:#f39c12}.items-section{margin-bottom:25px}.items-list{background:#f8f9fa;border-radius:8px;padding:15px}.item-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid #e1e8ed}.item-row:last-child{border-bottom:none}.item-info{flex:1;display:flex;flex-direction:column;gap:6px}.item-name{font-weight:500;color:#2c3e50;font-size:14px}.item-promotion{display:flex;align-items:center;gap:8px;margin-top:4px}.promotion-badge{background:#e8f5e8;color:#27ae60;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;border:1px solid #c8e6c9}.promotion-discount{background:#fff3cd;color:#856404;padding:2px 6px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid #ffeaa7}.item-group-promotion{margin-top:4px}.group-promotion-badge{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;border:1px solid #bbdefb}.group-promotion-discount{background:#fff3cd;color:#856404;padding:2px 6px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid #ffeaa7;margin-left:8px}.item-details{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:120px}.item-details span{font-size:13px;color:#7f8c8d}.original-price{text-decoration:line-through;color:#95a5a6!important;font-size:12px!important}.discounted-price{color:#e74c3c!important;font-weight:600!important}.item-total{font-weight:600;color:#27ae60!important;font-size:14px!important}.group-promotions-section{margin-bottom:25px}.group-promotions-section h4{margin:0 0 15px;color:#2c3e50;font-size:16px;font-weight:600}.group-promotions-list{background:#f0f8ff;border-radius:8px;padding:15px;border:1px solid #bbdefb}.group-promotion-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #e3f2fd}.group-promotion-row:last-child{border-bottom:none}.group-promotion-info{display:flex;flex-direction:column;gap:4px}.group-promotion-name{font-weight:600;color:#1976d2;font-size:14px}.group-promotion-items{font-size:12px;color:#666}.group-promotion-discount{text-align:right}.discount-amount{background:#fff3cd;color:#856404;padding:4px 8px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid #ffeaa7}.discount-row{background:#fff3cd;border-radius:6px;padding:8px 12px!important;margin:4px 0;border:1px solid #ffeaa7}.discount-row span:first-child{color:#856404;font-weight:600}.discount-row .discount-amount{background:#f39c12;color:#fff;font-weight:700}.totals-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:20px;border-radius:12px;border:1px solid #dee2e6;box-shadow:0 2px 8px #0000001a}.totals-section h4{margin:0 0 15px;color:#2c3e50;font-size:18px;font-weight:700;text-align:center;border-bottom:2px solid #3498db;padding-bottom:10px}.totals-grid{display:flex;flex-direction:column;gap:8px}.total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#fff;border-radius:8px;border-left:4px solid #e9ecef;transition:all .3s ease}.total-row:hover{transform:translate(5px);box-shadow:0 2px 8px #0000001a}.subtotal-amount{font-weight:600;color:#6c757d}.subtotal-discounted{font-weight:600;color:#28a745}.tax-amount{font-weight:600;color:#fd7e14}.final-total{border:2px solid #28a745;background:linear-gradient(135deg,#d4edda,#c3e6cb);margin-top:15px;padding:15px;font-weight:700;font-size:18px;color:#155724;border-left:4px solid #28a745}.final-amount{font-size:20px;font-weight:800;color:#155724}.items-section{margin-bottom:25px;width:100%}.items-section h4{margin:0 0 15px;color:#2c3e50;font-size:16px;font-weight:600}.items-table-container{margin-top:15px;border-radius:8px;overflow:hidden;border:1px solid #e1e8ed;width:100%}.items-table{width:100%;border-collapse:collapse;background:#fff;table-layout:fixed}.items-table thead{background:#f8f9fa}.items-table th{padding:12px 15px;text-align:left;font-weight:600;color:#2c3e50;font-size:13px;border-bottom:2px solid #e1e8ed;white-space:nowrap}.items-table th:nth-child(1){width:40%;min-width:200px;text-align:left}.items-table th:nth-child(2){width:15%;text-align:center}.items-table th:nth-child(3){width:20%;text-align:right}.items-table th:nth-child(4){width:10%;text-align:center}.items-table th:nth-child(5){width:15%;text-align:right}.items-table td:nth-child(1){width:40%;min-width:200px}.items-table td:nth-child(2){width:15%;text-align:center}.items-table td:nth-child(3){width:20%;text-align:right}.items-table td:nth-child(4){width:10%;text-align:center}.items-table td:nth-child(5){width:15%;text-align:right}.items-table tbody tr{border-bottom:1px solid #f1f3f4;width:100%}.items-table tbody tr:hover{background:#f8f9fa}.items-table .item-row{width:100%;display:table-row}.items-table td{padding:12px 15px;vertical-align:top;font-size:13px;color:#2c3e50;word-wrap:break-word;overflow-wrap:break-word}.items-table .product-info{max-width:350px;min-width:200px}.items-table .product-name{font-weight:600;color:#2c3e50;margin-bottom:4px;line-height:1.3}.items-table .product-id{font-size:11px;color:#7f8c8d;margin-bottom:2px}.items-table .sub-product-badge{background:#e8f5e8;color:#27ae60;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:500;margin-left:8px}.items-table .volume-info,.items-table .weight-info{font-size:11px;color:#7f8c8d;margin-top:2px}.items-table .quantity{text-align:center;font-weight:600;color:#3498db}.items-table .price{text-align:right}.items-table .price-with-discount{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.items-table .original-price{text-decoration:line-through;color:#95a5a6;font-size:11px}.items-table .discounted-price{color:#e74c3c;font-weight:600}.items-table .tax-rate{text-align:center;font-size:12px;color:#7f8c8d}.items-table .subtotal{text-align:right;font-weight:600;color:#27ae60}.promotion-row{background:#f0f8ff!important}.promotion-info{padding:8px 15px!important;font-size:12px!important;color:#1976d2!important;font-style:italic}.group-promotion-row{background:#fff8e1!important}.group-promotion-info{padding:8px 15px!important;font-size:12px!important;color:#f57c00!important;font-style:italic}@media (max-width: 768px){.sales-history-screen{padding:15px}.filters-header{flex-direction:column;gap:12px;align-items:stretch}.filters-title{font-size:16px}.export-btn{width:100%;justify-content:center}.filters-content{padding:16px;flex-direction:column;gap:16px}.filter-group:nth-child(1),.filter-group:nth-child(2),.filter-group:nth-child(3){min-width:100%;flex:1 1 100%}.filter-type-selector{flex-direction:column}.filter-option{min-width:100%}.date-range-inputs{flex-direction:column;gap:12px;align-items:stretch}.date-input-wrapper{min-width:100%}.date-separator{display:none}.vendor-select{min-width:100%}.header-top{flex-direction:column;align-items:flex-start;gap:8px}.header-filters{grid-template-columns:1fr;gap:10px}.date-input-group{flex-wrap:wrap;justify-content:center}.metrics-grid{grid-template-columns:1fr}.daily-sales-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.table-header,.table-row{grid-template-columns:60px 120px 80px 100px 100px 60px;font-size:12px;padding:10px 15px}.modal-content{margin:10px;max-height:90vh}.modal-header,.modal-body{padding:15px 20px}}.vendor-filter{display:flex;align-items:center;gap:10px}.vendor-label{font-size:14px;color:#2c3e50;font-weight:500}.vendor-select{border:2px solid #e1e8ed;border-radius:8px;padding:8px 10px;font-size:14px;color:#2c3e50;background:#fff}.header-actions{display:flex;align-items:center;gap:10px}.primary-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;border:none;background:#2563eb;color:#fff;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 6px #0000001f;transition:background-color .2s,transform .05s}.primary-btn:hover{background:#1d4ed8}.primary-btn:active{transform:translateY(1px)}.export-btn{background:linear-gradient(135deg,#3b82f6,#2563eb)}.sales-history-screen .action-btn{padding:8px;border:1px solid #e1e8ed}.sales-history-screen .action-btn:hover{background-color:#f3f6fb}.loading-overlay{position:fixed;inset:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-in}.loading-overlay-content{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;animation:slideUp .3s ease-out}.loading-overlay-text{font-size:16px;font-weight:500;color:#042959;text-align:center;max-width:300px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:20px;background:#fff;border-radius:8px;border:2px solid #e1e8ed}.pagination-btn{padding:8px 16px;background:#fff;border:2px solid #e1e8ed;border-radius:6px;color:#2c3e50;font-weight:600;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){border-color:#3498db;color:#3498db;background:#f8f9fa}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f8f9fa}.pagination-info{font-size:14px;font-weight:600;color:#2c3e50}.chart-section{margin-top:20px;background:#fff;padding:20px;border-radius:12px;border:2px solid #e1e8ed;box-shadow:0 4px 6px #0000000d}.chart-section h3{margin:0 0 20px;font-size:16px;color:#2c3e50;font-weight:600;border-bottom:2px solid #f0f2f5;padding-bottom:10px}.chart-container{height:280px;width:100%;position:relative;padding-bottom:30px;display:flex;align-items:stretch}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding-right:12px;margin-right:8px;border-right:1px dashed #e1e8ed;height:100%;min-width:60px;padding-bottom:4px}.y-axis-label{font-size:11px;color:#95a5a6;font-weight:600;line-height:1}.hourly-chart{display:flex;height:100%;align-items:flex-end;justify-content:space-between;gap:4px;flex:1;position:relative}.hourly-chart:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 24%,rgba(0,0,0,.03) 25%);pointer-events:none;z-index:0}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative;cursor:pointer;justify-content:flex-end;z-index:1}.chart-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;border-radius:4px 4px 0 0;height:100%}.chart-bar{width:70%;background:linear-gradient(180deg,#3498db,#2980b9);border-radius:4px 4px 0 0;transition:height .5s ease-out,background .2s;min-height:2px;box-shadow:0 2px 4px #3498db33}.chart-bar-wrapper:hover .chart-bar{background:linear-gradient(180deg,#2ecc71,#27ae60);filter:brightness(1.1);width:85%;box-shadow:0 4px 8px #2ecc714d}.chart-label{font-size:10px;color:#95a5a6;margin-top:8px;font-weight:500;transform:rotate(-45deg);transform-origin:center top;white-space:nowrap;position:absolute;top:100%}.chart-bar-wrapper:hover .chart-label{color:#2c3e50;font-weight:700;z-index:2}.spinner{width:14px;height:14px;border:2px solid rgba(52,152,219,.1);border-left-color:#3498db;border-radius:50%;animation:spinner-spin .6s linear infinite;display:inline-block}@keyframes spinner-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.table-row.expanded{background-color:#f8fafc;border-bottom:none;border-left:3px solid #3b82f6;transition:background-color .2s ease}.sale-details-inline{background-color:#f8fafc;border-left:3px solid #3b82f6;border-bottom:1px solid #e2e8f0;padding:0 20px 20px;animation:slideDown .2s cubic-bezier(.4,0,.2,1);margin-top:-1px;position:relative;z-index:10;box-shadow:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sale-details-inline .items-section,.sale-details-inline .discount-characteristics{background:transparent;border:none;box-shadow:none;padding:10px 0;margin-bottom:0}.sale-details-inline .items-section:last-child,.sale-details-inline .discount-characteristics:last-child{margin-bottom:0}.sale-details-inline .items-section h4,.sale-details-inline .discount-characteristics h4{margin-top:0;margin-bottom:15px;font-size:13px;font-weight:700;color:#64748b;border-bottom:none;padding-bottom:0;text-transform:uppercase;letter-spacing:.05em}.sale-details-inline .items-table{width:100%;border-collapse:collapse;background:transparent}.sale-details-inline .items-table th{background-color:transparent;color:#94a3b8;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;padding:8px 12px;border-bottom:1px solid #e2e8f0;text-align:left}.sale-details-inline .items-table th:nth-child(1){width:35%}.sale-details-inline .items-table th:nth-child(2){width:12%;text-align:center}.sale-details-inline .items-table th:nth-child(3){width:8%;text-align:center}.sale-details-inline .items-table th:nth-child(4){width:12%;text-align:right}.sale-details-inline .items-table th:nth-child(5){width:13%;text-align:center}.sale-details-inline .items-table th:nth-child(6){width:8%;text-align:right}.sale-details-inline .items-table th:nth-child(7){width:12%;text-align:right}.sale-details-inline .items-table td{padding:10px 12px;border-bottom:1px dashed #e2e8f0;color:#334155;font-size:13px;vertical-align:middle;background:transparent}.sale-details-inline .items-table td:nth-child(2),.sale-details-inline .items-table td:nth-child(3),.sale-details-inline .items-table td:nth-child(5){text-align:center}.sale-details-inline .items-table td:nth-child(4),.sale-details-inline .items-table td:nth-child(6),.sale-details-inline .items-table td:nth-child(7){text-align:right}.sale-details-inline .items-table td{padding:12px;border-bottom:1px solid #f1f5f9;color:#334155;font-size:13px;vertical-align:middle}.sale-details-inline .items-table tr:last-child td{border-bottom:none}.inline-details-header,.inline-actions{display:none}.action-btn.active{background-color:#3b82f6;color:#fff;box-shadow:0 2px 4px #3b82f64d}.action-btn.active:hover{background-color:#2563eb}.view-btn .spinner{border-width:2px;width:14px;height:14px}.row-loader-bar{position:absolute;bottom:0;left:0;height:3px;width:100%;background-color:#3498db1a;overflow:hidden;z-index:10;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.row-loader-bar:after{content:"";position:absolute;top:0;left:0;height:100%;width:50%;background:linear-gradient(90deg,transparent,#3498db,transparent);animation:loading-bar-move 1s infinite cubic-bezier(.4,0,.2,1)}@keyframes loading-bar-move{0%{transform:translate(-150%)}to{transform:translate(250%)}}.promotion-badge-row{display:inline-flex;align-items:center;margin-top:4px;background-color:#f0fdf4;padding:3px 8px;border-radius:6px;border:1px solid #dcfce7;max-width:100%}.promotion-badge-row.group{background-color:#f1f5f9;border-color:#e2e8f0;margin-top:4px}.promotion-badge-unified{font-size:11px;font-weight:600;color:#166534;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.promotion-badge-unified.group{color:#334155}.promotion-badge,.promotion-amount{display:none}.discounts-grid-summary{display:grid;gap:8px;max-width:500px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #f1f5f9}.summary-row.manual{border-left:3px solid #f59e0b}.summary-row.promo{border-left:3px solid #22c55e}.summary-row.group{border-left:3px solid #3b82f6}.summary-row.total-saved{background:#f0fdf4;border:1px solid #bbf7d0;margin-top:8px}.summary-label{font-size:13px;color:#64748b;font-weight:500}.summary-value{font-size:14px;font-weight:700;color:#334155}.summary-row.total-saved .summary-label{color:#166534;font-weight:700;text-transform:uppercase;font-size:12px}.summary-row.total-saved .summary-value{color:#15803d;font-size:15px}.group-promotions-screen{padding:20px;max-width:1200px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.header h1{color:#333;margin:0;font-size:2rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:#f8f9fa;color:#6c757d;border:2px solid #dee2e6;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.btn-secondary:hover{background:#e9ecef;border-color:#adb5bd}.error-message{background:#fee;color:#c33;padding:15px;border-radius:8px;margin-bottom:20px;border-left:4px solid #c33;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#c33;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.loading{text-align:center;padding:40px;color:#666;font-size:1.1rem}.product-selection-section{display:flex;flex-direction:column;gap:16px;background:#fff;padding:0;border-radius:8px}.btn-select-products{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;align-self:flex-start;display:flex;align-items:center;gap:8px}.btn-select-products:hover{background:#e2e8f0;color:#1e293b;border-color:#cbd5e1}.selected-products-preview{display:flex;flex-direction:column;gap:12px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.selected-products-preview h4{margin:0;padding:12px 16px;font-size:.85rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e2e8f0}.selected-products-tags{display:flex;flex-direction:column;max-height:200px;overflow-y:auto}.product-tag{background:#fff;border-bottom:1px solid #f1f5f9;padding:10px 16px;font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background .2s}.product-tag:last-child{border-bottom:none}.product-tag:hover{background:#f8fafc}.remove-product-tag{background:transparent;color:#94a3b8;border:none;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .2s;padding:0}.remove-product-tag:hover{background:#fee2e2;color:#ef4444}.promotions-table-container{overflow-x:auto;margin-top:20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000000d;border:1px solid #e0e0e0}.promotions-table{width:100%;border-collapse:collapse;min-width:800px}.promotions-table th,.promotions-table td{padding:12px 10px;text-align:left;border-bottom:1px solid #e0e0e0}.promotions-table th{background-color:#f8f9fa;font-weight:600;color:#495057;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.promotions-table tr:hover{background-color:#f8f9fa}.promotions-table tr:last-child td{border-bottom:none}.promotions-table .inactive-row{background-color:#fcfcfc;opacity:.8}.promotions-table .inactive-row td{color:#888}.col-name{font-size:.95rem;color:#333}.col-desc{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;color:#666}.col-discount{font-weight:600;color:#28a745;white-space:nowrap}.col-rules{font-size:.85rem;min-width:100px}.text-muted{color:#6c757d;font-size:.8rem}.status-badge{display:inline-block;padding:4px 8px;border-radius:20px;font-size:.75rem;font-weight:600;text-align:center;white-space:nowrap}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.col-actions{white-space:nowrap;width:1%}.action-buttons{display:flex;gap:8px;flex-wrap:nowrap;align-items:center}.btn-action{padding:0 12px;height:32px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;min-width:80px}.btn-toggle-status{min-width:95px}.btn-toggle-status.btn-activate{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.btn-toggle-status.btn-activate:hover{background-color:#c3e6cb}.btn-toggle-status.btn-deactivate{background-color:#fff3cd;color:#856404;border-color:#ffeeba}.btn-toggle-status.btn-deactivate:hover{background-color:#ffeeba}.btn-edit-text{background-color:#cce5ff;color:#004085;border-color:#b8daff}.btn-edit-text:hover{background-color:#b8daff}.btn-delete-text{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.btn-delete-text:hover{background-color:#f5c6cb}.empty-state{padding:40px!important;color:#6c757d;font-style:italic;text-align:center}@keyframes pulse-dots{0%,to{box-shadow:0 -3px 0 .2px,6px -3px,12px -3px}25%{box-shadow:0 -3px,6px -3px 0 .2px,12px -3px}50%{box-shadow:0 -3px,6px -3px,12px -3px 0 .2px}}.loading-dots{display:inline-block;width:3px;height:3px;border-radius:50%;position:relative;margin-left:-6px;margin-top:3px;animation:pulse-dots 1s infinite linear;color:inherit}.btn-toggle-status.btn-activate .loading-dots{color:#155724}.btn-toggle-status.btn-deactivate .loading-dots{color:#856404}.btn-delete-text .loading-dots{color:#721c24}.btn-action.loading-state{pointer-events:none;opacity:.8}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:12px;width:95%;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h2{margin:0;color:#333;font-size:1.5rem}.btn-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.btn-close:hover{background:#e9ecef;color:#333}.modal-form{padding:24px;overflow-y:auto;flex:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.product-search{margin-bottom:10px}.search-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.products-selection{max-height:200px;overflow-y:auto;border:2px solid #e0e0e0;border-radius:8px;padding:12px;background:#f8f9fa}.product-checkbox{display:flex;align-items:center;cursor:pointer;transition:background-color .2s ease;border-radius:4px;padding:8px;margin-bottom:4px}.product-checkbox:hover{background:#e9ecef}.product-checkbox input[type=checkbox]{margin-right:12px;width:auto;transform:scale(1.2)}.product-checkbox span{font-size:14px;color:#333}.product-info{display:flex;flex-direction:column;gap:2px}.product-name{font-size:14px;color:#333;font-weight:500}.product-type{font-size:12px;color:#6c757d;font-style:italic}.parent-product{font-size:11px;color:#28a745;font-weight:500}.error-text{color:#dc3545;font-size:.85rem;margin-top:4px;display:block}.modal-actions{display:flex;gap:16px;justify-content:flex-end;padding:24px 32px;border-top:1px solid #e0e0e0;background:#f8f9fa;border-radius:0 0 12px 12px;position:sticky;bottom:0}.modal-actions button{padding:12px 24px;font-size:1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.modal-actions .btn-secondary{background:#fff;color:#64748b;border:1px solid #cbd5e1}.modal-actions .btn-secondary:hover{background:#f1f5f9;color:#1e293b;border-color:#94a3b8}.modal-actions .btn-primary{background:#2563eb;color:#fff;border:none;box-shadow:0 4px 6px -1px #2563eb33,0 2px 4px -1px #2563eb1a}.modal-actions .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#60a5fa,#3b82f6);transform:translateY(-1px);box-shadow:0 10px 15px -3px #2563eb4d,0 4px 6px -2px #2563eb26}.modal-actions .btn-primary:disabled{background:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.toggle-switch-group{display:flex;align-items:center;gap:12px;background:#f8fafc;padding:12px 16px;border-radius:8px;border:1px solid #e2e8f0}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0000001a}input:checked+.slider{background-color:#2563eb}input:focus+.slider{box-shadow:0 0 1px #2563eb}input:checked+.slider:before{transform:translate(24px)}.toggle-label{font-weight:500;color:#334155;font-size:.95rem}@media (max-width: 768px){.group-promotions-screen{padding:15px}.header{flex-direction:column;gap:15px;align-items:stretch}.header h1{font-size:1.5rem;text-align:center}.form-row{grid-template-columns:1fr}.modal{margin:10px;max-height:calc(100vh - 20px)}.modal-actions{flex-direction:column}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.promotions-table tr{animation:slideIn .3s ease-out}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.loading{animation:pulse 1.5s ease-in-out infinite}.days-selector{display:flex;gap:8px;margin-top:8px;width:100%}.day-checkbox{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff;text-align:center}.day-checkbox:hover{border-color:#cbd5e1;background:#f8fafc}.day-checkbox input[type=checkbox]{margin:0;cursor:pointer;accent-color:#2563eb}.day-checkbox span{font-size:.85rem;font-weight:500;color:#64748b}.day-checkbox:has(input:checked){border-color:#2563eb;background:#eff6ff;color:#2563eb}.day-checkbox:has(input:checked) span{color:#2563eb;font-weight:600}.error-text{color:#dc3545;font-size:.875rem;margin-top:4px;display:block}@media (max-width: 768px){.days-selector{gap:8px}.day-checkbox{min-width:80px;padding:6px 10px;font-size:.875rem}}.price-update-screen{padding:20px;max-width:1400px;margin:0 auto;position:relative}.notification{position:fixed;top:20px;right:20px;z-index:1000;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out}.notification.success{background-color:#10b981;color:#fff}.notification.error{background-color:#ef4444;color:#fff}.notification-content{display:flex;align-items:center;gap:8px}.notification-content button{background:none;border:none;color:inherit;cursor:pointer;padding:2px;border-radius:4px;transition:background-color .2s}.notification-content button:hover{background-color:#fff3}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.screen-header h2{margin:0;color:#1f2937;font-size:28px;font-weight:700}.history-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.history-btn:hover{background-color:#5856eb;transform:translateY(-1px)}.price-update-content{display:grid;grid-template-columns:1fr;gap:24px}.update-form-section{display:flex;justify-content:center}.form-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb;width:100%;max-width:500px}.form-card h3{margin:0 0 20px;color:#1f2937;font-size:20px;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;gap:8px;padding:12px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;background-color:#f9fafb}.radio-option:hover{border-color:#6366f1;background-color:#f0f9ff}.radio-option input[type=radio]:checked+*{border-color:#6366f1;background-color:#eff6ff}.radio-option input[type=radio]{margin:0}.form-select,.form-input{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;transition:border-color .2s;background-color:#fff}.form-select:focus,.form-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.percentage-input{position:relative;display:flex;align-items:center}.percentage-input .form-input{padding-right:40px}.percentage-symbol{position:absolute;right:12px;color:#6b7280;font-weight:500;pointer-events:none}.form-actions{margin-top:24px}.btn-preview{width:100%;padding:12px 24px;background-color:#10b981;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-preview:hover:not(:disabled){background-color:#059669;transform:translateY(-1px)}.btn-preview:disabled{background-color:#9ca3af;cursor:not-allowed;transform:none}.history-section{margin-top:24px}.history-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.history-card h3{margin:0 0 20px;color:#1f2937;font-size:20px;font-weight:600}.history-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.history-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid #e5e7eb;border-radius:8px;background-color:#f9fafb;transition:all .2s}.history-item:hover{background-color:#f3f4f6;border-color:#d1d5db}.history-info{flex:1}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.history-type{display:flex;align-items:center;gap:6px;font-weight:500;color:#374151}.history-percentage{font-weight:600;padding:4px 8px;border-radius:4px;font-size:14px}.history-percentage.positive{background-color:#dcfce7;color:#166534}.history-percentage.negative{background-color:#fee2e2;color:#991b1b}.history-details{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:#6b7280}.undo-btn{padding:8px;background-color:#f59e0b;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.undo-btn:hover:not(:disabled){background-color:#d97706;transform:scale(1.05)}.undo-btn:disabled{background-color:#9ca3af;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;overflow-y:auto;width:100%}.preview-modal{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.modal-header h3{margin:0;color:#1f2937;font-size:20px;font-weight:600}.close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.close-btn:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:0 24px 24px}.preview-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;padding:20px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.summary-item{display:flex;justify-content:space-between;align-items:center}.summary-item span:first-child{color:#6b7280;font-size:14px}.summary-item strong{font-weight:600;font-size:16px}.summary-item strong.positive{color:#059669}.summary-item strong.negative{color:#dc2626}.preview-products{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.products-header{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr;gap:12px;padding:12px 16px;background-color:#f3f4f6;font-weight:600;font-size:14px;color:#374151;border-bottom:1px solid #e5e7eb}.products-list{max-height:300px;overflow-y:auto}.product-row{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr;gap:12px;padding:12px 16px;border-bottom:1px solid #f3f4f6;font-size:14px;align-items:center}.product-row:last-child{border-bottom:none}.product-row:hover{background-color:#f9fafb}.col-name{font-weight:500;color:#1f2937}.col-supplier{color:#6b7280}.col-price,.col-new-price{font-weight:500;text-align:right}.col-change{font-weight:600;text-align:right}.col-change.positive{color:#059669}.col-change.negative{color:#dc2626}.more-products{padding:16px;text-align:center;color:#6b7280;font-style:italic;background-color:#f9fafb}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e5e7eb;background-color:#f9fafb}.btn-cancel{padding:10px 20px;background-color:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-cancel:hover{background-color:#4b5563}.btn-apply{padding:10px 20px;background-color:#dc2626;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-apply:hover:not(:disabled){background-color:#b91c1c}.btn-apply:disabled{background-color:#9ca3af;cursor:not-allowed}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin:0;font-size:16px}@media (max-width: 768px){.price-update-screen{padding:16px}.screen-header{flex-direction:column;gap:16px;align-items:flex-start}.screen-header h2{font-size:24px}.form-card{padding:20px}.radio-group{gap:8px}.radio-option{padding:10px}.history-details{flex-direction:column;gap:4px}.products-header,.product-row{grid-template-columns:1fr;gap:8px}.products-header{display:none}.product-row{display:block;padding:16px}.product-row>div{margin-bottom:8px}.product-row>div:last-child{margin-bottom:0}.col-name:before{content:"Producto: ";font-weight:400;color:#6b7280}.col-supplier:before{content:"Proveedor: ";font-weight:400;color:#6b7280}.col-price:before{content:"Precio actual: ";font-weight:400;color:#6b7280}.col-new-price:before{content:"Precio nuevo: ";font-weight:400;color:#6b7280}.col-change:before{content:"Cambio: ";font-weight:400;color:#6b7280}.modal-content{margin:10px;max-height:calc(100vh - 20px)}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}@media (max-width: 480px){.preview-summary{grid-template-columns:1fr}.summary-item{flex-direction:column;align-items:flex-start;gap:4px}}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}.confirmation-message{text-align:center;padding:20px}.change-details{background:#f3f4f6;padding:12px;border-radius:6px;margin:16px 0;border-left:4px solid #fbbf24}.user-admin-screen{padding:2rem;max-width:1400px;margin:0 auto;background-color:#f8fafc;min-height:100vh}.screen-header{margin-bottom:2rem;text-align:center}.header-title{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.header-title h1{margin:0;color:#1e293b;font-size:2.5rem;font-weight:700}.header-subtitle{color:#64748b;font-size:1.1rem;margin:0}.alert{display:flex;align-items:center;gap:.5rem;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-weight:500}.alert-error{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}.alert-success{background-color:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.loading-spinner{text-align:center}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.users-container{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.empty-state{text-align:center;padding:4rem 2rem;color:#64748b}.empty-state svg{color:#cbd5e1;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:#475569}.empty-state p{margin:0}.users-grid{display:grid;gap:2rem;padding:2rem}.user-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.user-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.user-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.user-info h3{margin:0 0 .25rem;color:#1e293b;font-size:1.25rem;font-weight:600}.user-email{margin:0 0 .25rem;color:#64748b;font-size:.9rem}.user-id{margin:0;color:#94a3b8;font-size:.8rem;font-family:monospace}.user-actions{display:flex;gap:.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background-color:#059669}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.permissions-grid{display:grid;gap:1rem}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.permission-info{flex:1}.permission-label{display:block;font-weight:600;color:#1e293b;margin-bottom:.25rem;cursor:default}.permission-description{margin:0;color:#64748b;font-size:.875rem}.permission-control{margin-left:1rem}.permission-status{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500}.permission-status.granted{background-color:#dcfce7;color:#16a34a}.permission-status.denied{background-color:#fef2f2;color:#dc2626}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px #0000004d}input:checked+.toggle-slider{background-color:#10b981}input:checked+.toggle-slider:before{transform:translate(26px)}@media (min-width: 768px){.users-grid{grid-template-columns:repeat(auto-fit,minmax(600px,1fr))}.permissions-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1200px){.permissions-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.user-admin-screen{padding:1rem}.screen-header{margin-bottom:1.5rem}.header-title{flex-direction:column;gap:.5rem}.header-title h1{font-size:1.5rem}.header-title svg{width:28px;height:28px}.header-subtitle{font-size:.95rem}.users-container{border-radius:.5rem}.users-grid{padding:1rem;gap:1.25rem}.user-card{padding:1.25rem}.user-header{flex-direction:column;gap:1rem;align-items:stretch}.user-actions .btn{min-height:44px;min-width:44px}.permission-item{flex-direction:column;align-items:stretch;gap:.75rem;padding:.875rem}.permission-control{margin-left:0;align-self:flex-end}.toggle-switch{width:52px;height:28px}.toggle-slider:before{height:22px;width:22px}input:checked+.toggle-slider:before{transform:translate(24px)}}@media (max-width: 480px){.user-admin-screen{padding:.75rem}.header-title h1{font-size:1.35rem}.users-grid{padding:.75rem}}
