@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap";:root{--brand-gold:#d1a153;--brand-gold-hover:#c09043;--brand-gold-light:#d1a1531a;--brand-gold-border:#d1a15340;--bg-cream:#f9f8f6;--card-white:#fff;--text-charcoal:#1c1917;--text-gray:#78716c;--border-light:#f0efea;--success-green:#2ecc71;--danger-red:#e74c3c;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-serif:"Playfair Display", Georgia, serif;--shadow-sm:0 2px 8px #0000000a;--shadow-md:0 8px 24px #d1a1530f;--shadow-lg:0 16px 40px #d1a1531a;--transition-smooth:all .25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-cream);color:var(--text-charcoal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}.login-container{background-color:var(--bg-cream);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background-color:var(--card-white);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--brand-gold-border);text-align:center;border-radius:24px;padding:32px 24px;animation:.5s ease-out fadeIn}.login-logo{background-color:var(--brand-gold-light);width:72px;height:72px;color:var(--brand-gold);border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex;box-shadow:0 8px 20px #d1a1531f}.login-title{font-family:var(--font-serif);color:var(--brand-gold);margin-bottom:8px;font-size:2.2rem;font-weight:700}.login-subtitle{color:var(--text-gray);margin-bottom:28px;font-size:.9rem}.form-group{text-align:left;margin-bottom:16px}.form-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-gray);margin-bottom:6px;font-size:.8rem;font-weight:700;display:block}.form-input{width:100%;font-family:var(--font-sans);background-color:var(--bg-cream);border:1px solid var(--border-light);color:var(--text-charcoal);transition:var(--transition-smooth);border-radius:12px;padding:12px 14px;font-size:.95rem}.form-input:focus{border-color:var(--brand-gold);background-color:var(--card-white);outline:none;box-shadow:0 0 0 4px #d1a1531f}.btn-primary{width:100%;font-family:var(--font-sans);color:var(--card-white);background-color:var(--brand-gold);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:12px;margin-top:10px;padding:14px;font-size:.95rem;font-weight:700;box-shadow:0 4px 12px #d1a15326}.btn-primary:hover{background-color:var(--brand-gold-hover)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary{width:100%;font-family:var(--font-sans);color:var(--text-gray);border:1px solid var(--border-light);cursor:pointer;transition:var(--transition-smooth);background-color:#0000;border-radius:12px;padding:12px;font-size:.9rem;font-weight:600}.btn-secondary:hover{background-color:var(--bg-cream);color:var(--text-charcoal)}.error-banner{color:var(--danger-red);text-align:left;background-color:#e74c3c14;border:1px solid #e74c3c33;border-radius:12px;margin-bottom:20px;padding:12px;font-size:.85rem}.success-banner{color:var(--success-green);text-align:left;background-color:#2ecc7114;border:1px solid #2ecc7133;border-radius:12px;margin-bottom:20px;padding:12px;font-size:.85rem}.app-container{flex-direction:column;min-height:100vh;display:flex}.client-header{background-color:var(--card-white);border-bottom:1px solid var(--border-light);z-index:90;justify-content:center;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.client-header-title{font-family:var(--font-serif);color:var(--brand-gold);font-size:1.4rem;font-weight:700}.client-content{flex:1;width:100%;max-width:600px;margin:0 auto;padding:24px 16px 88px}.bottom-nav{background-color:var(--card-white);border-top:1px solid var(--border-light);z-index:100;justify-content:space-around;align-items:center;height:64px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #00000005}.bottom-nav-item{color:var(--text-gray);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;height:100%;font-size:.72rem;font-weight:700;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--brand-gold)}.bottom-nav-item.active svg{transform:scale(1.1)}.loyalty-card{background-color:var(--card-white);width:100%;height:200px;box-shadow:var(--shadow-md);border:1px solid var(--brand-gold-border);cursor:pointer;transition:var(--transition-smooth);border-radius:24px;flex-direction:column;justify-content:space-between;margin-bottom:24px;padding:24px;display:flex;position:relative;overflow:hidden}.loyalty-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#d1a1530d 0%,#0000 70%);width:250px;height:250px;position:absolute;top:-50%;right:-20%}.loyalty-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.loyalty-card-brand{font-family:var(--font-serif);letter-spacing:2px;color:var(--brand-gold);font-size:1.2rem;font-weight:700}.loyalty-card-sub{letter-spacing:1.5px;color:var(--text-gray);margin-top:2px;font-size:.55rem;font-weight:700}.loyalty-card-visits-title{color:var(--text-gray);text-transform:uppercase;letter-spacing:1px;font-size:.6rem;font-weight:700}.loyalty-card-visits-value{color:var(--text-charcoal);margin-top:4px;font-size:2rem;font-weight:800;line-height:1.1}.progress-card{background-color:var(--card-white);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:20px;margin-bottom:24px;padding:20px}.progress-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.progress-title{color:var(--text-charcoal);font-size:.95rem;font-weight:700}.progress-subtitle{color:var(--text-gray);font-size:.8rem}.stamp-grid{grid-template-columns:repeat(5,1fr);gap:12px;margin:16px 0;display:grid}.stamp-cell{aspect-ratio:1;color:#d1a1534d;transition:var(--transition-smooth);border:2px dashed #d1a1534d;border-radius:50%;justify-content:center;align-items:center;display:flex}.stamp-cell.active{border-style:solid;border-color:var(--brand-gold);background-color:var(--brand-gold-light);color:var(--brand-gold);animation:.3s cubic-bezier(.175,.885,.32,1.275) popIn}.section-title{font-family:var(--font-serif);color:var(--text-charcoal);align-items:center;gap:8px;margin:28px 0 16px;font-size:1.25rem;font-weight:700;display:flex}.rewards-grid{grid-template-columns:1fr;gap:16px;display:grid}.reward-card{background-color:var(--card-white);border:1px solid var(--border-light);transition:var(--transition-smooth);border-radius:16px;justify-content:space-between;align-items:center;padding:16px;display:flex}.reward-card:hover{border-color:var(--brand-gold-border);box-shadow:var(--shadow-sm)}.reward-info{flex:1;padding-right:16px}.reward-name{color:var(--text-charcoal);margin-bottom:4px;font-size:.95rem;font-weight:700}.reward-desc{color:var(--text-gray);font-size:.8rem;line-height:1.4}.reward-cost{color:var(--brand-gold);margin-top:6px;font-size:.75rem;font-weight:700}.category-bar{scrollbar-width:none;gap:8px;margin-bottom:16px;padding:4px 0 16px;display:flex;overflow-x:auto}.category-bar::-webkit-scrollbar{display:none}.category-tab{border:1px solid var(--border-light);background-color:var(--card-white);color:var(--text-charcoal);font-family:var(--font-sans);cursor:pointer;white-space:nowrap;transition:var(--transition-smooth);border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:700}.category-tab.active{background-color:var(--brand-gold);border-color:var(--brand-gold);color:var(--card-white);box-shadow:0 4px 10px #d1a15326}.products-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;display:grid}.product-card{background-color:var(--card-white);border:1px solid var(--border-light);border-radius:16px;flex-direction:column;height:100%;padding:12px;display:flex}.product-img{object-fit:cover;background-color:var(--bg-cream);border-radius:12px;width:100%;height:100px;margin-bottom:10px}.product-fallback-img{background-color:var(--brand-gold-light);width:100%;height:100px;color:var(--brand-gold);border-radius:12px;justify-content:center;align-items:center;margin-bottom:10px;display:flex}.product-name{color:var(--text-charcoal);-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-bottom:4px;font-size:.9rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.product-tags{flex-wrap:wrap;gap:4px;height:16px;margin-bottom:6px;display:flex}.tag-badge{text-transform:uppercase;border-radius:4px;padding:1px 4px;font-size:.55rem;font-weight:700}.tag-vegan{color:#27ae60;background-color:#2ecc711f}.tag-vegetarian{color:#2980b9;background-color:#3498db1f}.tag-organic{color:#16a085;background-color:#1abc9c1f}.tag-healthy{color:#d35400;background-color:#e67e221f}.product-desc{color:var(--text-gray);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:auto;font-size:.72rem;line-height:1.4;display:-webkit-box;overflow:hidden}.store-card{background-color:var(--card-white);border:1px solid var(--border-light);border-radius:20px;margin-bottom:20px;padding:20px}.store-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.store-name{color:var(--text-charcoal);font-size:1.1rem;font-weight:700}.store-badge{background-color:var(--brand-gold-light);color:var(--brand-gold);border-radius:6px;padding:4px 8px;font-size:.65rem;font-weight:700}.store-details{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.store-detail-item{color:var(--text-gray);align-items:flex-start;gap:8px;font-size:.8rem;display:flex}.store-detail-item svg{color:var(--brand-gold);flex-shrink:0;margin-top:2px}.store-actions{gap:12px;display:flex}.btn-store-action{font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:.8rem;font-weight:700;display:flex}.btn-store-action.primary{background-color:var(--brand-gold);color:var(--card-white);border:none}.btn-store-action.primary:hover{background-color:var(--brand-gold-hover)}.btn-store-action.secondary{border:1px solid var(--border-light);color:var(--brand-gold);background-color:#0000}.btn-store-action.secondary:hover{background-color:var(--bg-cream)}.social-links-wrapper{background-color:var(--card-white);border:1px solid var(--border-light);border-radius:16px;margin-top:24px;padding:16px}.social-links-title{color:var(--text-charcoal);margin-bottom:12px;font-size:.9rem;font-weight:700}.social-grid{gap:12px;display:flex}.social-btn{border:1px solid var(--border-light);font-family:var(--font-sans);color:var(--brand-gold);cursor:pointer;transition:var(--transition-smooth);background-color:#0000;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:.8rem;font-weight:600;text-decoration:none;display:flex}.social-btn:hover{background-color:var(--bg-cream)}.profile-card{background-color:var(--card-white);text-align:center;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);border-radius:24px;margin-bottom:24px;padding:32px 20px}.profile-avatar{background-color:var(--brand-gold-light);width:80px;height:80px;color:var(--brand-gold);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;font-size:1.8rem;font-weight:700;display:flex}.profile-name{font-family:var(--font-serif);color:var(--text-charcoal);margin-bottom:4px;font-size:1.3rem;font-weight:700}.profile-email{color:var(--text-gray);margin-bottom:16px;font-size:.85rem}.btn-inline-edit{background-color:var(--brand-gold-light);color:var(--brand-gold);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:12px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:700;display:inline-flex}.btn-inline-edit:hover{background-color:#d1a1532e}.profile-menu{background-color:var(--card-white);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);border-radius:20px;overflow:hidden}.profile-menu-item{text-align:left;width:100%;font-family:var(--font-sans);color:var(--text-charcoal);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;align-items:center;gap:16px;padding:16px 20px;font-size:.95rem;font-weight:600;display:flex}.profile-menu-item:not(:last-child){border-bottom:1px solid var(--border-light)}.profile-menu-item:hover{background-color:var(--bg-cream)}.profile-menu-item.danger{color:var(--danger-red)}.profile-menu-item svg{flex-shrink:0}.profile-menu-item .chevron{color:var(--text-gray);opacity:.5;margin-left:auto}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background-color:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=600px){.modal-backdrop{align-items:center}}.modal-content{background-color:var(--card-white);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;align-items:center;width:100%;max-width:500px;max-height:90vh;padding:24px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow-y:auto;box-shadow:0 -8px 32px #00000026}@media (width>=600px){.modal-content{border-radius:24px;margin:20px;animation:.3s cubic-bezier(.16,1,.3,1) zoomIn}}.modal-drag-handle{background-color:#e2e8f0;border-radius:3px;width:40px;height:5px;margin-bottom:20px}.modal-title{font-family:var(--font-serif);color:var(--text-charcoal);text-align:center;margin-bottom:8px;font-size:1.3rem;font-weight:700}.modal-desc{color:var(--text-gray);text-align:center;margin-bottom:24px;font-size:.85rem;line-height:1.4}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:.5;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.scanner-viewport{aspect-ratio:1;border:4px solid var(--brand-gold);background-color:#000;border-radius:20px;width:100%;max-width:320px;margin-bottom:20px;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%}.scanner-laser{background-color:var(--danger-red);height:3px;box-shadow:0 0 8px var(--danger-red);z-index:10;animation:2s linear infinite scanLaser;position:absolute;left:0;right:0}@keyframes scanLaser{0%{top:0%}50%{top:100%}to{top:0%}}
