:root{font-family:Poppins,Nunito,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#3c2440;--pink: #f54992;--pink-dark: #d12e6c;--cream: #fff5fb;--soft-gray: #f3f3f5;--shadow: 0 20px 40px rgba(211, 44, 111, .25)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(180deg,#ffe4f0,#fff 30%,#ffe4f0);background-attachment:fixed;color:#3c2440}#root{min-height:100vh}a{color:inherit}.app-shell{min-height:100vh;padding:clamp(1rem,3vw,2.5rem);background:#fff;display:flex;flex-direction:column;gap:1.5rem;position:relative;overflow:hidden}.brand-card{background:var(--pink);color:#fff;border-radius:32px;padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem;position:relative;z-index:2}.dashboard-header{position:relative;z-index:2;display:flex;justify-content:center;align-items:flex-start;padding:clamp(1rem,3vw,2rem) clamp(1rem,3vw,2rem) 0}.menu-toggle{position:absolute;left:clamp(1rem,3vw,2rem);top:clamp(1rem,3vw,2rem);background:var(--pink);color:#fff;border:none;border-radius:12px;width:48px;height:48px;font-size:1.5rem;cursor:pointer;box-shadow:var(--shadow);transition:all .2s ease;z-index:100;display:flex;align-items:center;justify-content:center}.menu-toggle:hover{transform:scale(1.05)}.menu-toggle:active{transform:scale(.95)}.dashboard-logo{max-width:min(260px,100%);height:auto}.logout-button{position:absolute;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);background:#fff;border:none;border-radius:999px;padding:.75rem 1.5rem;font-weight:600;color:var(--pink-dark);cursor:pointer;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.logout-button:hover{transform:translateY(-2px)}.login-layout{min-height:100vh;background:var(--pink);display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,5vw,4rem);position:relative;overflow:hidden}.login-layout.fade-in{animation:fadeIn .8s ease-in-out;animation-delay:.4s;animation-fill-mode:both}.login-card.fade-in-up{animation:fadeInUp .8s ease-out;animation-delay:.6s;animation-fill-mode:both}.login-card{width:min(440px,100%);background:#fff;color:#3c2440;border-radius:36px;padding:clamp(1.75rem,4vw,3rem);box-shadow:0 30px 70px #3c244040;display:flex;flex-direction:column;gap:1.25rem;text-align:center;position:relative;z-index:2}.login-card form{text-align:left}.login-drip,.dashboard-drip{position:absolute;bottom:0;left:0;width:100%;pointer-events:none;z-index:1}.login-drip{position:absolute;top:0;right:0;width:100%;pointer-events:none;z-index:1}.brand-card img{max-width:240px}.panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;position:relative;z-index:2}.dashboard-customers-card{grid-column:span 2}.dashboard-customers-header{display:flex;justify-content:space-between;align-items:center}.dashboard-customers-header img.dashboard-customers-icon{width:60px;height:60px}@media(max-width:768px){.dashboard-customers-card{grid-column:span 1}}.glass-card{background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:28px;padding:1.75rem;box-shadow:0 20px 50px #3c244026;display:flex;flex-direction:column;gap:1rem}.stamp-grid{display:grid;grid-template-columns:repeat(5,minmax(44px,1fr));gap:.5rem}.stamp{width:56px;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;border:2px solid var(--pink);color:var(--pink);font-weight:600;transition:all .25s ease}.stamp.filled{background:radial-gradient(circle at 30% 30%,#ffd4ec 0%,var(--pink) 100%);color:#fff;border-color:transparent;box-shadow:0 12px 20px #ff3f934d}.action-button{background:#fff;border:none;border-radius:999px;padding:.75rem 1.5rem;font-weight:600;color:var(--pink-dark);cursor:pointer;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.action-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.action-button:hover:not(:disabled){transform:translateY(-2px)}form{display:flex;flex-direction:column;gap:.75rem}label{font-size:.9rem;font-weight:600}input,select,textarea{border:none;border-radius:18px;padding:.85rem 1.25rem;font-size:1rem;background:#f8f4f6;transition:outline .2s ease}input:focus,select:focus,textarea:focus{outline:2px solid rgba(255,63,147,.4)}.login-transition{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;pointer-events:none;overflow:hidden}.login-transition-bg{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--pink);z-index:0}.login-transition-paint{position:absolute;top:0;left:0;width:100%;height:0;background:#fff;z-index:1;transform-origin:top}.login-transition-paint.animating{animation:paintDown 2s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes paintDown{0%{height:0}to{height:100%}}.login-transition-drip{position:absolute;top:0;left:0;width:100%;height:auto;object-fit:cover;object-position:top;transform:translateY(0);transition:transform 2s cubic-bezier(.25,.46,.45,.94);z-index:2;will-change:transform}.login-transition-drip.animating{transform:translateY(calc(100vh - 100%));object-position:bottom}.login-transition.logout .login-transition-bg,.login-transition.logout .login-transition-bg.logout-bg{background:#fff}.login-transition.logout .login-transition-paint{background:var(--pink);top:auto;bottom:0;height:0;transform-origin:bottom}.login-transition.logout .login-transition-paint.animating{animation:paintUp 2s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes paintUp{0%{height:0}to{height:100%}}.login-transition.logout .login-transition-drip{top:auto;bottom:0;transform:translateY(0);object-position:bottom}.login-transition.logout .login-transition-drip.animating{transform:translateY(calc(-100vh + 100%));object-position:top}.app-shell.fade-in{animation:fadeIn .8s ease-in-out;animation-delay:.4s;animation-fill-mode:both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dashboard-header,.panel-grid{animation:fadeInUp .8s ease-out;animation-delay:.6s;animation-fill-mode:both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.app-shell{padding:.75rem;gap:1rem}.dashboard-header{padding:.75rem .75rem 0;flex-direction:column;align-items:center;gap:.75rem}.dashboard-logo{max-width:180px}.logout-button{position:relative;top:auto;right:auto;padding:.5rem 1rem;font-size:.85rem;width:auto}.panel-grid{grid-template-columns:1fr;gap:1rem}.glass-card{padding:1.25rem;border-radius:20px;gap:.75rem}.glass-card h2{font-size:1.25rem;margin:0}.glass-card small{font-size:.8rem}.dashboard-customers-header{flex-direction:column;align-items:flex-start;gap:.75rem}.dashboard-customers-header img.dashboard-customers-icon{width:50px;height:50px}.stamp-grid{grid-template-columns:repeat(5,minmax(40px,1fr));gap:.4rem}.stamp{width:48px;font-size:.85rem}.action-button{padding:.5rem 1rem;font-size:.85rem;white-space:nowrap}.brand-card{text-align:center;align-items:center}input,select,textarea{padding:.7rem 1rem;font-size:.95rem;border-radius:14px}label{font-size:.85rem}form{gap:.6rem}.glass-card>div[style*=maxHeight]{max-height:300px!important;padding-right:.25rem!important}.glass-card>div[style*="display: flex"][style*="justifyContent: space-between"]{flex-wrap:wrap;gap:.5rem!important}.glass-card>div[style*="display: flex"][style*="gap: 0.5rem"]{gap:.5rem!important}.glass-card>div[style*=paddingBlock]{padding-block:.75rem!important}.glass-card strong{font-size:.95rem}.glass-card p{font-size:.9rem}}@media(max-width:480px){.app-shell{padding:.5rem;gap:.75rem}.dashboard-header{padding:.5rem .5rem 0}.dashboard-logo{max-width:150px}.glass-card{padding:1rem;border-radius:18px}.glass-card h2{font-size:1.1rem}.action-button{padding:.45rem .9rem;font-size:.8rem}input,select,textarea{padding:.6rem .9rem;font-size:.9rem}.stamp{width:42px;font-size:.8rem}.dashboard-customers-card>div:first-child img{width:45px;height:45px}}.sidebar{position:fixed;top:0;left:0;width:300px;max-width:85vw;height:100vh;background:#fff;box-shadow:4px 0 20px #3c244026;z-index:1001;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.sidebar.open{transform:translate(0)}.sidebar-header{display:flex;justify-content:center;align-items:center;padding:1.5rem;border-bottom:1px solid #f3d4e3}.sidebar-logo{max-width:160px;height:auto}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-item{width:100%;background:transparent;border:none;padding:1.25rem 1.5rem;font-weight:600;font-size:1.1rem;color:#6f4c56;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:1rem;text-align:left}.sidebar-icon{font-size:1.5rem;flex-shrink:0}.sidebar-item:hover{background:#f8f4f6}.sidebar-item.active{background:var(--pink);color:#fff}.sidebar-footer{padding:1rem;border-top:1px solid #f3d4e3}.sidebar-logout{width:100%;background:#fee6ef;border:none;border-radius:14px;padding:1rem 1.5rem;font-weight:600;font-size:1.1rem;color:#d12e6c;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem}.sidebar-logout:hover{background:#ffd4ec;transform:translateY(-2px)}.sidebar-logout:active{transform:translateY(0) scale(.98)}.sidebar-logout .sidebar-icon{font-size:1.25rem}.sidebar-overlay{position:fixed;inset:0;background:#3c244080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;display:block}.qr-scan-button{background:var(--pink);color:#fff;border:none;border-radius:999px;padding:1.5rem 3rem;font-weight:600;font-size:1.25rem;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;width:100%;gap:.75rem}.qr-scan-icon{font-size:2rem;flex-shrink:0}.qr-scan-button:hover{transform:translateY(-4px);box-shadow:0 25px 50px #d32c6f66}.qr-scan-button:active{transform:translateY(-2px)}.modal-overlay{position:fixed;inset:0;background:#3c2440b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:28px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 30px 70px #3c24404d;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#3c2440}.modal-close{background:#f8f4f6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;color:#6f4c56;transition:all .2s ease}.modal-close:hover{background:#fee6ef;transform:rotate(90deg)}.modal-body{display:flex;flex-direction:column;gap:1rem}.qr-scanner-modal{position:fixed;inset:0;background:#3c2440e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.qr-scanner-content{background:#fff;border-radius:28px;padding:2rem;max-width:600px;width:100%;box-shadow:0 30px 70px #3c24404d;position:relative}.qr-scanner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.qr-scanner-header h2{margin:0;color:#3c2440}.qr-scanner-close{background:#f8f4f6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;color:#6f4c56;transition:all .2s ease}.qr-scanner-close:hover{background:#fee6ef;transform:rotate(90deg)}.qr-scanner-error{margin-top:1rem;padding:1rem;background:#fee6ef;border-radius:18px;color:#d12e6c;text-align:center}#qr-reader{border-radius:18px;overflow:hidden}#qr-reader__dashboard_section_csr{border-radius:18px}@media(max-width:768px){.dashboard-header{justify-content:center}.sidebar{width:280px}.qr-scan-button{padding:1.25rem 2rem;font-size:1.1rem}.modal-content,.qr-scanner-content{padding:1.5rem;border-radius:20px}.modal-header h2,.qr-scanner-header h2{font-size:1.25rem}}@media(max-width:480px){.sidebar{width:260px}.qr-scan-button{padding:1rem 1.5rem;font-size:1rem}.sidebar-item{padding:1rem 1.25rem;font-size:1rem}}
