*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}:root{--brand-blue: #029ad5;--brand-green: #25CF03;--lojista-bg: #029ad5;--checkout-bg: #f0f2f5;--page-text: #ffffff;--surface: #ffffff;--card-border: #eeeeee;--price-color: #198754;--old-price-color: #dc3545;--island-bg: rgba(255,255,255,.94);--island-active: #029ad5;--island-active-bg: rgba(2,154,213,.12);--section-title-color: #444444;--section-border: #f0f0f0;--text-muted: #888888;--radius-card: 12px;--radius-section: 20px}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background-color:var(--brand-blue);min-height:100dvh;overflow-x:hidden}.global-toast-container{position:fixed;bottom:96px;left:50%;transform:translate(-50%);z-index:9999;width:max-content;max-width:90vw}.global-toast-container .toast{border-radius:var(--radius-card);font-size:.9rem}.page-topbar{display:flex;align-items:center;padding:.75rem 1rem 0;gap:.75rem}.btn-back-icon{color:var(--page-text);font-size:1.6rem;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;text-decoration:none;background:none;border:none;padding:0}.btn-back-icon:hover{background:#ffffff26;color:var(--page-text)}.page-title-white{color:var(--page-text);font-size:clamp(1.2rem,4vw,1.6rem);font-weight:700;margin:0}.content-section{background:var(--surface);border-radius:var(--radius-section) var(--radius-section) 0 0;padding:1rem;flex:1;min-height:calc(100dvh - 160px);padding-bottom:110px}.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 480px){.products-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 768px){.products-grid{grid-template-columns:repeat(4,1fr)}}.product-card{border-radius:var(--radius-card);overflow:hidden;border:1px solid var(--card-border);cursor:pointer;display:flex;flex-direction:column;background:var(--surface);-webkit-user-select:none;user-select:none;transition:transform .15s,box-shadow .15s}.product-card:active{transform:scale(.97)}.product-card img{width:100%;height:120px;object-fit:cover}.product-card-body{padding:.5rem;display:flex;flex-direction:column;flex:1}.product-card-title{font-size:.82rem;font-weight:600;color:#222;margin:0 0 .2rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-desc{font-size:.72rem;color:var(--text-muted);margin:0 0 .25rem;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.product-card-old-price{font-size:.72rem;color:var(--old-price-color);text-decoration:line-through;margin:0}.product-card-price{font-size:.92rem;font-weight:700;color:var(--price-color);margin:0 0 .5rem}.btn-add-cart{font-size:.78rem;padding:.4rem .5rem;border-radius:8px;min-height:36px;margin-top:auto}.search-bar .form-control{font-size:1rem;height:48px}.search-bar .btn{min-width:48px;height:48px;font-size:1.1rem}.stop-scan-btn{min-height:44px}.cart-island{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:var(--island-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:999px;padding:.3rem .75rem;box-shadow:0 4px 28px #0000002e;display:flex;align-items:center;gap:.15rem;z-index:1050;border:1px solid rgba(255,255,255,.7);justify-content:center;animation:islandPop .55s cubic-bezier(.22,1,.36,1) .15s both}.island-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;text-decoration:none;color:#6c757d;font-weight:500;font-size:.7rem;padding:.4rem .9rem;border-radius:999px;transition:background .15s,color .15s;white-space:nowrap;min-width:60px;min-height:52px;justify-content:center;cursor:pointer;border:none;background:none}.island-btn i{font-size:1.35rem}.island-btn:hover{background:#0000000f;color:#1a1a1a}.island-btn.active{color:var(--island-active);font-weight:700;background:var(--island-active-bg)}.island-sep{width:1px;height:30px;background:#0000001a;border-radius:1px;flex-shrink:0}.island-badge{display:none;position:absolute;top:2px;right:6px;background:var(--old-price-color);color:#fff;border-radius:999px;font-size:.6rem;font-weight:700;min-width:17px;height:17px;line-height:17px;text-align:center;padding:0 3px;border:2px solid var(--surface)}.island-cart-wrap{position:relative}.section-title{font-size:1rem;font-weight:700;color:var(--section-title-color);padding-bottom:.75rem;border-bottom:2px solid var(--section-border);margin-bottom:.75rem}.login-card{background-color:var(--surface);padding:2.5rem;border-radius:8px;box-shadow:0 4px 12px #00000026;width:100%;max-width:420px}.product-image-thumb{width:100%;height:200px;object-fit:cover}.product-manage-card{transition:box-shadow .3s}.product-manage-card:hover{box-shadow:0 0 15px #00000026}.cart-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 0;border-bottom:1px solid var(--section-border)}.cart-item:last-child{border-bottom:none}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-size:.95rem;font-weight:600;color:#1a1a1a;margin:0 0 .15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-unit-price{font-size:.78rem;color:var(--text-muted);margin:0}.cart-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.cart-item-subtotal{font-size:.95rem;font-weight:700;color:var(--price-color);margin:0}.qty-control{display:flex;align-items:center;gap:.3rem;background:#f5f5f5;border-radius:8px;padding:.15rem .35rem}.qty-btn{width:30px;height:30px;border:none;background:#e0e0e0;border-radius:6px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.qty-btn:active{background:#c8c8c8}.qty-value{font-size:.95rem;font-weight:700;min-width:22px;text-align:center}.btn-remove{background:none;border:none;color:var(--old-price-color);font-size:1.1rem;padding:.25rem;cursor:pointer;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px}.btn-remove:active{background:#ffeaea}.cart-footer{padding-top:1rem;border-top:2px solid var(--section-border);margin-top:.5rem}.cart-total{font-size:1.25rem;font-weight:800;color:#1a1a1a;text-align:right;margin:0 0 1rem}.cart-total span{color:var(--price-color)}.btn-finish{width:100%;height:52px;font-size:1.05rem;font-weight:700;border-radius:14px;margin-bottom:.6rem}.btn-clear{width:100%;height:44px;font-size:.9rem;border-radius:14px}.empty-cart{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-cart i{font-size:3.5rem;margin-bottom:.75rem;display:block}.product-detail-card{background:var(--surface);border-radius:var(--radius-section) var(--radius-section) 0 0;min-height:calc(100dvh - 130px);padding-bottom:110px;overflow:hidden;margin-top:1rem}.product-detail-img{width:100%;max-height:300px;object-fit:cover}.product-info{padding:1.25rem 1.25rem 1.5rem}.product-name{font-size:clamp(1.1rem,4vw,1.4rem);font-weight:700;color:#1a1a1a;margin:0 0 .4rem}.product-description{font-size:.92rem;color:#666;margin:0 0 1rem;line-height:1.5}.price-old{font-size:.9rem;color:var(--old-price-color);text-decoration:line-through;margin:0 0 .15rem}.price-current{font-size:1.75rem;font-weight:800;color:var(--price-color);margin:0 0 1.25rem;line-height:1}.action-row{display:flex;align-items:center;gap:.75rem}.qty-control-lg{display:flex;align-items:center;gap:.5rem;background:#f5f5f5;border-radius:12px;padding:.25rem .5rem;flex-shrink:0}.qty-btn-lg{width:36px;height:36px;border-radius:8px;border:none;background:#e0e0e0;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none}.qty-btn-lg:active{background:#c8c8c8}.qty-value-lg{font-size:1.1rem;font-weight:700;min-width:28px;text-align:center;color:#1a1a1a}.btn-checkout{flex:1;height:48px;font-size:1rem;font-weight:600;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:background .15s,transform .1s}.btn-checkout:active{transform:scale(.97)}.checkout-card{max-width:450px;margin:3rem auto}#qrcode-pix{width:256px;height:256px;margin:1rem auto;border:5px solid var(--surface);box-shadow:0 0 10px #0000001a}.btn-start{width:100%;max-width:320px;height:56px;font-size:1.1rem;font-weight:700;border-radius:16px;letter-spacing:.02em;box-shadow:0 4px 16px #0000002e;transition:transform .1s,box-shadow .1s}.btn-start:active{transform:scale(.97);box-shadow:0 2px 8px #00000026}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@keyframes slideDown{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes cardEnter{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes itemEnter{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes islandPop{0%{opacity:0;transform:translate(-50%) translateY(20px) scale(.88)}70%{transform:translate(-50%) translateY(-3px) scale(1.02)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes badgePop{0%,to{transform:scale(1)}50%{transform:scale(1.5)}}@keyframes logoEnter{0%{opacity:0;transform:scale(.88) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes btnEnter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.anim-logo{animation:logoEnter .5s cubic-bezier(.22,1,.36,1) both}.anim-btn{animation:btnEnter .45s cubic-bezier(.22,1,.36,1) .18s both}.anim-slide-down{animation:slideDown .38s cubic-bezier(.22,1,.36,1) both}.anim-slide-up{animation:slideUp .42s cubic-bezier(.22,1,.36,1) .08s both}.anim-fade-in{animation:fadeIn .35s ease .05s both}.anim-fade-up-1{animation:fadeInUp .38s cubic-bezier(.22,1,.36,1) .18s both}.anim-fade-up-2{animation:fadeInUp .38s cubic-bezier(.22,1,.36,1) .26s both}.anim-fade-up-3{animation:fadeInUp .38s cubic-bezier(.22,1,.36,1) .34s both}
