@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=Open+Sans:wght@300;400;500;600&display=swap&subset=latin);:root{--brand-green:#27ae60;--brand-green-light:#2ecc71;--brand-green-dark:#278c52;--brand-dark:#2c3e50;--brand-accent:#ffde59;--primary-color:#008036;--secondary-color:#5ba042;--accent-color:#ffde59;--light-green:#99bc9a;--dark-green:#278c52;--success:#5ba042;--warning:#ffde59;--danger:#e74c3c;--info:#3498db;--white:#ffffff;--black:#000000;--gray-50:#f8faf8;--gray-100:#ecf0f1;--gray-200:#bdc3c7;--gray-300:#95a5a6;--gray-400:#7f8c8d;--gray-500:#6c757d;--gray-600:#495057;--gray-700:#343a40;--gray-800:#2c3e50;--gray-900:#212529;--background-color:#f8faf8;--surface-color:#ffffff;--surface-hover:rgba(39, 174, 96, 0.08);--surface-active:rgba(39, 174, 96, 0.12);--text-color:#2c3e50;--text-secondary:#6c757d;--text-muted:#95a5a6;--text-inverse:#ffffff;--font-primary:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;--font-secondary:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;--font-mono:'SF Mono',Monaco,'Cascadia Code','Roboto Mono',Consolas,'Courier New',monospace;--text-xs:clamp(0.875rem, 0.8rem + 0.125vw, 0.9rem);--text-sm:clamp(1rem, 0.9rem + 0.1875vw, 1.05rem);--text-base:clamp(1rem, 0.95rem + 0.25vw, 1.125rem);--text-lg:clamp(1.125rem, 1rem + 0.3125vw, 1.3rem);--text-xl:clamp(1.25rem, 1.1rem + 0.375vw, 1.5rem);--text-2xl:clamp(1.5rem, 1.3rem + 0.5vw, 1.875rem);--text-3xl:clamp(1.875rem, 1.6rem + 0.6875vw, 2.25rem);--text-4xl:clamp(2.25rem, 1.9rem + 0.875vw, 3rem);--font-light:300;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--space-0:0;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px;--container-2xl:1400px;--container-full:100%;--sidebar-width:300px;--sidebar-width-mobile:100%;--content-gap:20px;--container-padding:20px;--layout-max-width:1400px;--radius-sm:4px;--radius-base:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--border-radius:10px;--shadow-sm:0 1px 2px 0 rgba(0, 0, 0, 0.05);--shadow-base:0 1px 3px 0 rgba(0, 0, 0, 0.1),0 1px 2px 0 rgba(0, 0, 0, 0.06);--shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.1),0 2px 4px -1px rgba(0, 0, 0, 0.06);--shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.1),0 4px 6px -2px rgba(0, 0, 0, 0.05);--shadow-xl:0 20px 25px -5px rgba(0, 0, 0, 0.1),0 10px 10px -5px rgba(0, 0, 0, 0.04);--box-shadow:0 2px 8px rgba(0, 128, 54, 0.1);--transition-fast:150ms cubic-bezier(0.4, 0, 0.2, 1);--transition-base:250ms cubic-bezier(0.4, 0, 0.2, 1);--transition-slow:350ms cubic-bezier(0.4, 0, 0.2, 1);--transition:all 0.3s ease;--transition-smooth:cubic-bezier(0.4, 0, 0.2, 1);--navbar-height:60px;--navbar-bg:#ffffff;--navbar-shadow:0 4px 20px rgba(0, 0, 0, 0.06);--navbar-border:rgba(0, 0, 0, 0.05);--hover-bg:rgba(39, 174, 96, 0.08);--active-bg:rgba(39, 174, 96, 0.12);--active-color:#27ae60;--badge-bg:#e74c3c;--mobile-breakpoint:768px;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:400;--z-modal:500;--z-popover:600;--z-tooltip:700;--z-toast:800;--z-navbar:1000;--z-maximum:9999}@media (prefers-color-scheme:dark){:root{--background-color:#1a1a1a;--surface-color:#2d2d2d;--text-color:#ffffff;--text-secondary:#a0a0a0;--navbar-bg:rgba(45, 45, 45, 0.95)}}@media (prefers-contrast:high){:root{--brand-green:#1a8a45;--text-color:#000000;--navbar-shadow:0 4px 20px rgba(0, 0, 0, 0.3)}}:root{--primary-color:#008036;--secondary-color:#5ba042;--accent-color:#ffde59;--light-green:#99bc9a;--dark-green:#278c52;--background-color:#f8faf8;--text-color:#2c3e50;--white:#ffffff;--light-gray:#ecf0f1;--dark-gray:#34495e;--success:#5ba042;--warning:#ffde59;--danger:#e74c3c;--info:#3498db;--border-radius:10px;--box-shadow:0 2px 8px rgba(0, 128, 54, 0.1);--transition:all 0.3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Open Sans',sans-serif;background-color:var(--background-color);color:var(--text-color);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif;font-weight:600;margin-bottom:1rem}.header{background:linear-gradient(135deg,var(--primary-color),var(--dark-green));color:#fff;padding:1rem 0;box-shadow:var(--box-shadow);position:sticky;top:0;z-index:100}.header .container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-family:Poppins,sans-serif;font-size:1.8rem;font-weight:700;text-decoration:none;color:#fff}.nav{display:flex;gap:2rem}.nav a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:var(--border-radius);transition:var(--transition)}.nav a:hover{background-color:rgba(255,255,255,.2)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.hero{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:3rem 0;text-align:center;position:relative;overflow:hidden}.hero::after{content:'';position:absolute;bottom:-50px;left:0;right:0;height:100px;background:var(--accent-color);transform:skewY(-3deg);opacity:.3}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.btn{display:inline-block;padding:.75rem 2rem;border-radius:var(--border-radius);text-decoration:none;font-weight:600;cursor:pointer;border:none;transition:var(--transition);text-align:center}.btn-primary{background-color:var(--accent-color);color:var(--primary-color);font-weight:700}.btn-primary:hover{background-color:#ffd633;transform:translateY(-2px);box-shadow:0 4px 12px rgba(255,222,89,.4)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{background-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,128,54,.3)}.btn-outline{background-color:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover{background-color:var(--primary-color);color:#fff}.tabs{display:flex;justify-content:center;margin:2rem 0;border-bottom:1px solid var(--light-gray)}.tab-button{padding:1rem 2rem;background:0 0;border:none;cursor:pointer;font-weight:600;color:var(--dark-gray);border-bottom:3px solid transparent;transition:var(--transition)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--accent-color);background:linear-gradient(to bottom,transparent 60%,rgba(255,222,89,.1))}.tab-content{display:none}.tab-content.active{display:block}.cards-grid{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);display:flex;flex-direction:row;overflow:hidden;transition:var(--transition);border:1px solid rgba(153,188,154,.2)}.card:hover{box-shadow:0 6px 20px rgba(0,128,54,.15);transform:translateX(5px)}.card-image{width:200px;min-height:150px;background:linear-gradient(135deg,var(--light-green),var(--secondary-color));display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;flex-shrink:0;position:relative}.card-content{flex:1;padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between}.card-header{flex:1}.card-body{margin:.5rem 0}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.offer-card{position:relative;min-height:150px}.offer-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;color:#fff;margin-bottom:.5rem}.badge-cashback{background-color:var(--secondary-color)}.badge-campione{background-color:var(--dark-green)}.badge-coupon{background-color:var(--accent-color);color:var(--primary-color)}.badge-expiry-warning{background-color:var(--danger);color:#fff;animation:pulse-red 1.5s infinite;position:absolute;top:.5rem;left:.5rem;z-index:10;overflow:hidden}.badge-expiry-warning::before{content:'⏰';margin-right:.3rem}.badge-participation-count{background-color:var(--info);color:#fff;font-size:.8rem;position:absolute;bottom:10px;left:10px;min-width:2.5rem;text-align:center;z-index:10;padding:.3rem .6rem;border-radius:15px;font-weight:600;box-shadow:0 2px 6px rgba(52,152,219,.3);transition:all .3s ease}.badge-participation-count::before{content:'👥 '}.badge-participation-count:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(52,152,219,.4)}@keyframes pulse-red{0%{background-color:var(--danger);transform:scale(1)}50%{background-color:#c0392b;transform:scale(1.05)}100%{background-color:var(--danger);transform:scale(1)}}.badge-container{position:relative;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.main-badge{position:absolute!important;top:.5rem!important;right:.5rem!important;z-index:10!important;margin:0!important}.offer-brand{color:var(--primary-color);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.offer-title{font-size:1.2rem;margin:.5rem 0}.offer-amount{font-size:1.8rem;font-weight:700;color:var(--primary-color);margin:.5rem 0}.offer-expiry{color:var(--dark-gray);font-size:.9rem}.offer-expiry.expired{color:var(--danger)}.sidebar{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:2rem;margin-bottom:2rem}.sidebar h3{color:var(--primary-color);margin-bottom:1.5rem}.filter-group{margin-bottom:2rem}.filter-group label{display:block;margin-bottom:.5rem;font-weight:600}.filter-group input,.filter-group select{width:100%;padding:.75rem;border:1px solid var(--light-gray);border-radius:var(--border-radius);font-size:1rem}.filter-group input:focus,.filter-group select:focus{outline:0;border-color:var(--secondary-color);box-shadow:0 0 0 3px rgba(91,160,66,.1)}@media (max-width:768px){.card{flex-direction:column}.card-image{width:100%;height:120px;min-height:120px}.cards-grid{padding:0 1rem}}.filter-group input:focus,.filter-group select:focus{outline:0;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(39,174,96,.1)}.scanner-container{background:#fff;border-radius:var(--border-radius);padding:2rem;text-align:center;box-shadow:var(--box-shadow);margin:2rem 0}.scanner-video{max-width:100%;border-radius:var(--border-radius);margin:1rem 0}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--dark-gray)}.form-control{width:100%;padding:.75rem;border:1px solid var(--light-gray);border-radius:var(--border-radius);font-size:1rem;transition:var(--transition)}.form-control:focus{outline:0;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(39,174,96,.1)}textarea.form-control{resize:vertical;min-height:120px}.alert{padding:1rem;border-radius:var(--border-radius);margin:1rem 0}.alert-success{background-color:rgba(46,204,113,.1);color:var(--success);border:1px solid rgba(46,204,113,.3)}.alert-warning{background-color:rgba(243,156,18,.1);color:var(--warning);border:1px solid rgba(243,156,18,.3)}.alert-danger{background-color:rgba(231,76,60,.1);color:var(--danger);border:1px solid rgba(231,76,60,.3)}.spinner{border:4px solid var(--light-gray);border-top:4px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:2rem auto}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.live-reports{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:2rem;margin:2rem 0}.report-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--light-gray)}.report-item:last-child{border-bottom:none}.report-location{font-weight:600;color:var(--primary-color)}.report-time{font-size:.9rem;color:var(--dark-gray)}.footer{background-color:var(--dark-gray);color:#fff;padding:3rem 0 1rem;margin-top:4rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h4{margin-bottom:1rem;color:var(--secondary-color)}.footer-section a{color:#fff;text-decoration:none;display:block;margin-bottom:.5rem;transition:var(--transition)}.footer-section a:hover{color:var(--secondary-color)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);opacity:.8}@media (max-width:768px){.container{padding:0 1rem}.header .container{flex-direction:column;gap:1rem}.nav{justify-content:center}.hero h1{font-size:2rem}.cards-grid{grid-template-columns:1fr}.tabs{flex-wrap:wrap}.tab-button{flex:1;min-width:120px}}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease-out}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.justify-center{justify-content:center}.items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}:root{--navbar-height:55px;--navbar-bg:#ffffff;--navbar-shadow:0 4px 20px rgba(0, 0, 0, 0.06);--navbar-border:rgba(0, 0, 0, 0.05);--brand-green:#27ae60;--brand-green-light:#2ecc71;--brand-dark:#2c3e50;--hover-bg:rgba(39, 174, 96, 0.08);--active-bg:rgba(39, 174, 96, 0.12);--active-color:#27ae60;--badge-bg:#e74c3c;--mobile-breakpoint:1024px;--transition-smooth:cubic-bezier(0.4, 0, 0.2, 1);--navbar-gap:12px;--navbar-font-size:14px;--navbar-padding-v:8px;--navbar-padding-h:12px}.banner-top{background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;text-align:center;padding:4px 12px;font-size:13px;font-weight:500}.navbar-unified{background:rgba(255,255,255,.98);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--navbar-shadow);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--navbar-border);transition:all .3s var(--transition-smooth)}.navbar-container{max-width:1400px;margin:0 auto;padding:0 20px;height:var(--navbar-height);display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;box-sizing:border-box;min-width:0}.navbar-brand{display:flex;align-items:center;flex-shrink:0;min-width:160px;max-width:200px}.logo-link{display:flex;align-items:center;text-decoration:none;gap:10px}.logo-img{height:40px;width:auto;transition:transform .3s var(--transition-smooth)}.logo-link:hover .logo-img{transform:scale(1.05) rotate(-2deg)}.logo-text{font-size:24px;font-weight:700;color:var(--brand-dark);background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.navbar-menu{display:flex;align-items:center;gap:8px;flex:1;justify-content:center;margin:0 16px;flex-wrap:nowrap;min-width:0;position:relative;z-index:1}.nav-link{display:inline-flex;align-items:center;gap:8px;padding:var(--navbar-padding-v) var(--navbar-padding-h);border-radius:12px;text-decoration:none;color:var(--brand-dark);font-weight:600;font-size:var(--navbar-font-size);font-family:var(--font-primary);transition:all .3s var(--transition-smooth);white-space:nowrap;position:relative;box-sizing:border-box;line-height:1;min-width:fit-content;flex-shrink:1}.nav-link::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--brand-green);transition:all .3s var(--transition-smooth);transform:translateX(-50%)}.nav-link:hover::after{width:80%}.nav-link:hover{background:var(--hover-bg);transform:translateY(-2px)}.nav-link.active{background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;box-shadow:0 2px 8px rgba(39,174,96,.15);transform:translateY(-1px)}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}.nav-icon{font-size:18px;line-height:1;flex-shrink:0;transition:transform .3s var(--transition-smooth)}.nav-link:hover .nav-icon{transform:scale(1.1) rotate(-5deg)}.nav-icon-svg{width:22px;height:22px;display:inline-block;flex-shrink:0;transition:all .3s var(--transition-smooth)}.nav-text{flex-shrink:0}.nav-link:hover .nav-icon-svg{transform:scale(1.1)}.navbar-actions{display:flex;align-items:center;gap:var(--navbar-gap);flex-shrink:0;min-width:fit-content;position:relative;z-index:1}.action-btn{position:relative;background:rgba(255,255,255,.9);border:2px solid rgba(39,174,96,.1);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s var(--transition-smooth)}.action-btn:hover{background:var(--hover-bg);border-color:var(--brand-green);transform:scale(1.1) rotate(-8deg);box-shadow:0 4px 12px rgba(39,174,96,.2)}.action-btn:active{transform:scale(.95)}.navbar-unified .action-btn .action-icon{width:22px;height:22px;min-width:22px;min-height:22px;max-width:22px;max-height:22px;flex-shrink:0}.navbar-unified .action-btn .wallet-icon{width:26px;height:26px;min-width:26px;min-height:26px;max-width:26px;max-height:26px;flex-shrink:0}.navbar-unified .navbar-actions .action-btn>.action-badge{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#e74c3c 0,#c0392b 100%);color:#fff;font-size:11px;font-weight:700;padding:3px 7px;border-radius:12px;min-width:20px;max-width:32px;text-align:center;box-shadow:0 2px 6px rgba(231,76,60,.3);animation:badgePulse 2s infinite;line-height:1.2;display:inline-block;width:auto;height:auto;box-sizing:border-box}.action-badge.hidden{display:none}@keyframes badgePulse{0%{transform:scale(1)}50%{transform:scale(1.05)}100%{transform:scale(1)}}.user-menu-container{position:relative}.user-menu-btn{display:flex;align-items:center;gap:10px;padding:4px 12px 4px 6px;background:linear-gradient(135deg,#fff 0,#f8f9fa 100%);border:2px solid transparent;background-clip:padding-box;position:relative;border-radius:30px;cursor:pointer;transition:all .3s cubic-bezier(.4, 0, .2, 1);box-shadow:0 2px 8px rgba(39,174,96,.12);max-width:200px;min-width:0}.user-menu-btn::before{content:'';position:absolute;inset:-2px;border-radius:30px;padding:2px;background:linear-gradient(135deg,#27ae60,#2ecc71);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:source-out;mask-composite:exclude;opacity:.3;transition:opacity .3s ease}.user-menu-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(39,174,96,.25)}.user-menu-btn:hover::before{opacity:1}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--navbar-font-size);font-family:var(--font-primary);flex-shrink:0;box-shadow:0 2px 6px rgba(39,174,96,.2);transition:all .3s var(--transition-smooth)}.user-menu-btn:hover .user-avatar{transform:scale(1.05);box-shadow:0 3px 10px rgba(39,174,96,.3)}.user-greeting{color:var(--brand-dark);font-size:var(--navbar-font-size);font-family:var(--font-primary);font-weight:600;line-height:1.2;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.dropdown-arrow{margin-left:4px;color:#6c757d;transition:transform .3s ease;display:flex;align-items:center}.user-menu-btn.active .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:12px;box-shadow:0 5px 25px rgba(0,0,0,.15);min-width:220px;display:none;animation:slideDown .3s ease;z-index:9999!important;border:1px solid rgba(0,0,0,.08)}.user-dropdown.show{display:block;visibility:visible!important}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:10px;padding:12px 18px;color:var(--brand-dark);text-decoration:none;font-size:14px;transition:all .2s ease}.dropdown-item:hover{background:var(--hover-bg);padding-left:22px}.dropdown-item.active{background:var(--hover-bg);font-weight:600;border-left:3px solid var(--brand-green);padding-left:15px}.dropdown-icon{width:16px;height:16px}.dropdown-divider{height:1px;background:var(--navbar-border);margin:5px 0}.logout-item{color:#e74c3c}.logout-item:hover{background:#fee}.btn-login{display:flex;align-items:center;gap:8px;padding:var(--navbar-padding-v) var(--navbar-padding-h);background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;border-radius:25px;text-decoration:none;font-weight:600;font-size:var(--navbar-font-size);font-family:var(--font-primary);transition:all .3s var(--transition-smooth);position:relative;overflow:hidden}.btn-login::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-login:hover::before{width:300px;height:300px}.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(39,174,96,.3)}.btn-login>*{position:relative;z-index:1}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:0;background:0 0;border:none;padding:0;cursor:pointer;width:40px;height:40px;border-radius:8px;transition:background .2s ease}.mobile-menu-toggle:hover{background:rgba(39,174,96,.08)}.mobile-menu-toggle:hover .hamburger-line{background:#27ae60}.hamburger-line{width:24px;height:2px;background:#2c3e50;display:block;border-radius:2px;transition:all .3s ease;margin:0}.hamburger-line:not(:last-child){margin-bottom:5px}.mobile-menu-toggle.active .hamburger-line:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.active .hamburger-line:nth-child(2){opacity:0}.mobile-menu-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.navbar-mobile{display:none;position:fixed;top:var(--navbar-height);left:0;right:0;background:#fff;box-shadow:0 5px 25px rgba(0,0,0,.15);max-height:calc(100vh - var(--navbar-height));overflow-y:auto;z-index:999}.navbar-mobile.show{display:block;animation:slideDown .3s ease}.mobile-menu-content{padding:20px}.mobile-link{display:flex;align-items:center;gap:12px;padding:15px 20px;margin:5px 0;border-radius:10px;text-decoration:none;color:var(--brand-dark);font-weight:500;font-size:16px;transition:all .2s ease}.mobile-link:hover{background:var(--hover-bg);padding-left:25px}.mobile-divider{height:1px;background:var(--navbar-border);margin:15px 0}.mobile-login{background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;text-align:center;justify-content:center}.mobile-logout{color:#e74c3c}.notifications-dropdown{position:fixed;top:calc(var(--navbar-height) + 10px);right:20px;background:#fff;border-radius:12px;box-shadow:0 5px 25px rgba(0,0,0,.15);width:350px;max-height:450px;z-index:998;display:flex;flex-direction:column}.notifications-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--navbar-border)}.notifications-header h4{margin:0;font-size:16px;color:var(--brand-dark)}.mark-read-btn{background:0 0;border:none;color:var(--brand-green);font-size:12px;cursor:pointer;font-weight:500}.notifications-list{flex:1;overflow-y:auto;padding:8px;max-height:400px}.notification-item{background:#fff;border-radius:10px;padding:14px 16px;margin-bottom:8px;cursor:pointer;transition:all .2s cubic-bezier(.4, 0, .2, 1);border:1px solid transparent;position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','SF Pro Text','Helvetica Neue',sans-serif;user-select:none}.notification-item:hover{background:#f8f9fa;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px rgba(59,130,246,.15)}.notification-item:active{transform:translateY(-1px)}.notification-item.unread{background:linear-gradient(135deg,#f0f7ff 0,#fef9f3 100%);border-color:#d4e7ff}.notification-item.unread:hover{background:linear-gradient(135deg,#e8f2ff 0,#fdf5eb 100%);border-color:#b8d7ff}.notification-item.unread::before{content:'';position:absolute;top:18px;left:-3px;width:8px;height:8px;background:linear-gradient(135deg,#3b82f6 0,#2563eb 100%);border-radius:50%;box-shadow:0 0 0 2px #fff,0 0 8px rgba(59,130,246,.4);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.notification-title{font-size:14px;font-weight:700;color:#1a1a1a;line-height:1.4;margin-bottom:6px;letter-spacing:-.01em}.notification-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;gap:8px}.notification-time{font-size:11px;color:#9ca3af;font-weight:500;letter-spacing:-.01em;flex:1}.notification-message{font-size:13px;color:#4b5563;line-height:1.5;margin:6px 0 0 0;letter-spacing:-.01em}.notification-message strong{font-weight:600;color:#1a1a1a}.notification-message em{font-style:italic;color:#6b7280}.notification-message code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:'SF Mono',Monaco,'Courier New',monospace;font-size:12px;color:#e11d48}.notification-mark-read-btn{flex-shrink:0;width:22px;height:22px;border-radius:4px;border:1.5px solid #3b82f6;background:#fff;color:#3b82f6;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;padding:0;line-height:1}.notification-mark-read-btn:hover{background:#3b82f6;color:#fff;transform:scale(1.05);box-shadow:0 1px 4px rgba(59,130,246,.3)}.notification-mark-read-btn:active{transform:scale(.9)}.error-notifications,.loading-notifications,.no-notifications{padding:40px 20px;text-align:center;color:#9ca3af;font-size:14px}.loading-notifications{color:#3b82f6}.error-notifications{color:#ef4444}.notifications-footer{padding:12px 16px;border-top:1px solid var(--navbar-border);text-align:center;background:#f9fafb;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.notifications-footer a{color:var(--brand-green);text-decoration:none;font-weight:500;font-size:14px}.navbar-unified .action-btn .action-badge[data-count="99"],span#favoritesCount.action-badge[data-count="99"]{font-size:10px;padding:3px 6px;font-weight:800;max-width:28px}@media (max-width:1024px){.navbar-container{padding:0 16px;gap:12px}.navbar-menu.desktop-menu{display:none}.mobile-menu-toggle{display:flex}.user-greeting{display:none}.user-menu-btn{padding:5px;gap:0;max-width:42px;border-radius:50%}.dropdown-arrow{display:none}.btn-login .login-text{display:none}.notifications-dropdown{width:calc(100vw - 40px);right:20px;left:20px}.navbar-actions{gap:10px}}@media (max-width:480px){.navbar-container{padding:0 12px;gap:8px}.logo-text{font-size:18px}.logo-img{height:32px}.navbar-brand{min-width:140px}.action-btn{width:32px;height:32px}.navbar-unified .action-btn .action-icon{width:18px;height:18px;min-width:18px;min-height:18px;max-width:18px;max-height:18px}.navbar-actions{gap:6px}.user-avatar{width:32px;height:32px;font-size:12px}.mobile-menu-toggle{width:32px;height:32px;gap:0;padding:0}.hamburger-line{width:18px;height:2px;display:block;background:#2c3e50;margin:0}.hamburger-line:not(:last-child){margin-bottom:4px}.notification-count{min-width:16px;height:16px;font-size:10px;padding:0 4px}}.navbar-search-container{position:relative;display:flex;align-items:center;margin:0 16px 0 48px;transition:all .3s ease;flex-shrink:0;z-index:10000}.search-trigger-btn{position:relative;background:rgba(255,255,255,.9);border:2px solid rgba(39,174,96,.1);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s var(--transition-smooth);color:#8b4513}.search-trigger-btn:hover{background:var(--hover-bg);border-color:var(--brand-green);transform:scale(1.1) rotate(-8deg);box-shadow:0 4px 12px rgba(39,174,96,.2)}.search-trigger-btn:active{transform:scale(.95)}.search-icon{display:block;width:22px;height:22px;min-width:22px}.search-input-wrapper{position:absolute;left:40px;display:flex;align-items:center;gap:0;opacity:0;width:0;height:0;overflow:hidden;transition:all .3s cubic-bezier(.4, 0, .2, 1);background-color:#fff;border-radius:24px;box-shadow:0 2px 8px rgba(0,0,0,.1);pointer-events:none;visibility:hidden;z-index:10000}.search-input-wrapper.expanded{opacity:1;width:250px;height:40px;padding:6px 12px;pointer-events:auto;visibility:visible;overflow:visible}.global-search-input{border:none;outline:0;flex:1;font-size:14px;padding:8px 40px 8px 8px;color:#333;background:0 0}.global-search-input::placeholder{color:#999}.barcode-scan-btn{position:absolute;right:8px;top:0;bottom:0;margin:auto 0;background:0 0;border:none;cursor:pointer;font-size:20px;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:transform .2s;z-index:10;pointer-events:auto}.barcode-scan-btn:hover{transform:scale(1.1)}.barcode-scan-btn:active{transform:scale(.95)}.search-results-dropdown{position:absolute;top:calc(100% + 8px);left:40px;width:450px;max-height:500px;overflow-y:auto;background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:1001;border:1px solid #e0e0e0}.search-results-list{padding:8px}.search-result-item{padding:12px;border-radius:8px;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.search-result-item:hover{background:#f8f8f8}.search-result-item img{width:50px;height:50px;object-fit:cover;border-radius:8px;flex-shrink:0}.search-result-info{flex:1}.search-result-title{font-weight:600;font-size:14px;margin-bottom:4px;color:#333}.search-result-meta{font-size:12px;color:#666}.search-no-results{padding:40px 20px;text-align:center;color:#999}.search-results-loading{padding:20px;text-align:center;color:#666}.search-suggestions-header{padding:10px 15px 8px;font-size:12px;font-weight:600;color:var(--brand-green);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(39,174,96,.15);background:rgba(39,174,96,.04)}.search-result-content{flex:1}.search-result-image{width:60px;height:60px;object-fit:cover;border-radius:8px;flex-shrink:0}.search-result-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.search-result-badge,.search-result-brand,.search-result-value{font-size:11px;padding:2px 6px;border-radius:4px;background:#f0f0f0;color:#666}.search-result-badge{background:#e8f5e8;color:#008036}.search-result-value{background:#fff3e0;color:#ff9800;font-weight:600}.search-view-all{display:block;padding:12px;text-align:center;background:linear-gradient(135deg,#e8f5e8 0,#f0f9ff 100%);color:#008036;font-weight:600;text-decoration:none;border-radius:8px;margin:8px;transition:background .2s}.search-view-all:hover{background:linear-gradient(135deg,#d4f1d4 0,#e0f3ff 100%)}.search-no-results p{margin-bottom:12px;font-size:14px}.search-no-results .search-view-all{display:inline-block;margin-top:12px}@media (max-width:992px){.navbar-search-container{margin:0 8px}.search-results-dropdown{width:100vw;left:-100px;max-width:400px}}@media (max-width:768px){.banner-top{padding:4px 6px;font-size:12px}.navbar-container{padding:0 4px 0 4px!important;gap:4px!important}.navbar-brand{min-width:0!important;flex-shrink:1}.logo-link{gap:4px!important}.logo-text{font-size:16px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-search-container{display:none}.btn-login,.favorites-btn,.user-menu-container{display:none!important}.navbar-actions{gap:4px!important;margin-left:auto;flex-shrink:0}}.mobile-search-btn{display:none;background:rgba(255,255,255,.9);border:2px solid rgba(39,174,96,.1);width:40px;height:40px;border-radius:50%;align-items:center;justify-content:center;cursor:pointer;transition:all .3s var(--transition-smooth);color:#8b4513;padding:0;margin-left:8px;flex-shrink:0}.mobile-search-btn:hover{background:var(--hover-bg);border-color:var(--brand-green);transform:scale(1.1)}.mobile-search-btn .search-icon{display:block;width:22px;height:22px;min-width:22px}.mobile-barcode-btn{display:none;background:rgba(255,255,255,.9);border:2px solid rgba(39,174,96,.1);width:40px;height:40px;border-radius:50%;align-items:center;justify-content:center;cursor:pointer;transition:all .3s var(--transition-smooth);color:#8b4513;padding:0;margin-left:5px;flex-shrink:0}.mobile-barcode-btn:hover{background:var(--hover-bg);border-color:var(--brand-green);transform:scale(1.1)}.mobile-barcode-btn:active{transform:scale(.95)}.mobile-barcode-btn .camera-icon{display:block;width:22px;height:22px;min-width:22px}.mobile-search-overlay{display:none;position:fixed;top:var(--navbar-height,60px);left:0;width:100vw;max-height:300px;background:#fff;z-index:99999;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 4px 12px rgba(0,0,0,.15);border-bottom:2px solid var(--gray-200)}.mobile-search-overlay.active{display:block;animation:slideInFromTop .3s ease}@keyframes slideInFromTop{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-search-header{display:none;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--brand-green);color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.1)}.mobile-search-header h3{margin:0;font-size:20px;font-weight:600}.mobile-search-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-search-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.mobile-search-content{padding:16px 12px}.mobile-search-input-wrapper{margin-bottom:20px}.mobile-search-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:12px;background:#f8f9fa;transition:all .3s ease}.mobile-search-input:focus{outline:0;border-color:var(--brand-green);background:#fff;box-shadow:0 2px 8px rgba(39,174,96,.1)}.mobile-barcode-btn-large{width:100%;display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,var(--brand-green) 0,#229954 100%);border:none;border-radius:16px;color:#fff;cursor:pointer;box-shadow:0 4px 12px rgba(39,174,96,.3);transition:all .3s ease;margin-bottom:24px}.mobile-barcode-btn-large:active{transform:scale(.98);box-shadow:0 2px 8px rgba(39,174,96,.2)}.barcode-icon-large{font-size:48px;line-height:1;flex-shrink:0}.barcode-text{text-align:left;flex:1}.barcode-text strong{display:block;font-size:18px;margin-bottom:4px;font-weight:600}.barcode-text small{display:block;font-size:14px;opacity:.9;font-weight:400}.mobile-search-results{margin-top:24px}.search-hint{text-align:center;color:#666;font-size:14px;padding:20px;background:#f8f9fa;border-radius:12px;line-height:1.6}@media (max-width:768px){.mobile-barcode-btn,.mobile-search-btn{display:flex}}@media (max-width:480px){.mobile-search-header h3{font-size:18px}.mobile-search-content{padding:16px}.mobile-barcode-btn-large{padding:16px}.barcode-icon-large{font-size:40px}.barcode-text strong{font-size:16px}.barcode-text small{font-size:13px}}.rimbo-toast-container{position:fixed;z-index:999999;pointer-events:none;max-width:420px}.rimbo-toast-container[data-position=top-right]{top:20px;right:20px}.rimbo-toast-container[data-position=bottom-center]{bottom:20px;left:50%;transform:translateX(-50%);max-width:calc(100% - 40px)}.rimbo-toast{position:relative;background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.05);padding:16px 20px;margin-bottom:10px;min-width:300px;max-width:100%;pointer-events:auto;opacity:0;transform:translateX(100%);transition:all .3s cubic-bezier(.4, 0, .2, 1);overflow:hidden}.rimbo-toast-mobile{min-width:280px;transform:translateY(100%)}.rimbo-toast-show{opacity:1;transform:translateX(0)}.rimbo-toast-mobile.rimbo-toast-show{transform:translateY(0)}.rimbo-toast-hide{opacity:0;transform:translateX(120%)}.rimbo-toast-mobile.rimbo-toast-hide{opacity:0;transform:translateY(120%)}.rimbo-toast-content{display:flex;align-items:flex-start;gap:12px}.rimbo-toast-icon{font-size:20px;flex-shrink:0;line-height:1;margin-top:2px}.rimbo-toast-body{flex:1;min-width:0}.rimbo-toast-message{font-size:14px;font-weight:500;line-height:1.5;color:#1a1a1a;word-wrap:break-word}.rimbo-toast-subtitle{font-size:12px;color:#666;margin-top:4px;line-height:1.4}.rimbo-toast-close{position:absolute;top:12px;right:12px;background:0 0;border:none;font-size:20px;line-height:1;color:#999;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.rimbo-toast-close:hover{background:rgba(0,0,0,.05);color:#333}.rimbo-toast-close:active{transform:scale(.95)}.rimbo-toast-close:focus{outline:2px solid #27ae60;outline-offset:2px}.rimbo-toast-actions{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.08)}.rimbo-toast-action-btn{background:0 0;border:1px solid currentColor;color:inherit;padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.rimbo-toast-action-btn:hover{background:rgba(0,0,0,.05)}.rimbo-toast-action-btn:active{transform:scale(.98)}.rimbo-toast-success{border-left:4px solid #27ae60}.rimbo-toast-success .rimbo-toast-icon{color:#27ae60}.rimbo-toast-success .rimbo-toast-action-btn{color:#27ae60}.rimbo-toast-error{border-left:4px solid #e74c3c}.rimbo-toast-error .rimbo-toast-icon{color:#e74c3c}.rimbo-toast-error .rimbo-toast-action-btn{color:#e74c3c}.rimbo-toast-warning{border-left:4px solid #f39c12}.rimbo-toast-warning .rimbo-toast-icon{color:#f39c12}.rimbo-toast-warning .rimbo-toast-action-btn{color:#f39c12}.rimbo-toast-info{border-left:4px solid #3498db}.rimbo-toast-info .rimbo-toast-icon{color:#3498db}.rimbo-toast-info .rimbo-toast-action-btn{color:#3498db}.rimbo-toast-tip{border-left:4px solid #9b59b6;background:linear-gradient(135deg,#fff 0,#f8f4ff 100%)}.rimbo-toast-tip .rimbo-toast-icon{color:#9b59b6}.rimbo-toast-tip .rimbo-toast-action-btn{color:#9b59b6}@media (max-width:768px){.rimbo-toast{min-width:280px;padding:14px 16px;border-radius:10px;font-size:13px}.rimbo-toast-icon{font-size:18px}.rimbo-toast-message{font-size:13px}.rimbo-toast-subtitle{font-size:11px}.rimbo-toast-close{top:10px;right:10px;font-size:18px}.rimbo-toast-action-btn{font-size:12px;padding:5px 12px}}@media (max-width:380px){.rimbo-toast{min-width:260px;padding:12px 14px}.rimbo-toast-container[data-position=bottom-center]{bottom:10px;max-width:calc(100% - 20px)}}@keyframes slideInRight{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideInUp{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}.rimbo-toast:focus-within{outline:2px solid #27ae60;outline-offset:2px}@media (prefers-reduced-motion:reduce){.rimbo-toast,.rimbo-toast-action-btn,.rimbo-toast-close,.rimbo-toast-hide,.rimbo-toast-show{transition:none;animation:none}}@media (prefers-contrast:high){.rimbo-toast{border:2px solid currentColor}.rimbo-toast-close:focus{outline-width:3px}}@media (prefers-color-scheme:dark){.rimbo-toast{background:#2c2c2c;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.1)}.rimbo-toast-message{color:#fff}.rimbo-toast-subtitle{color:#b3b3b3}.rimbo-toast-close{color:#b3b3b3}.rimbo-toast-close:hover{background:rgba(255,255,255,.1);color:#fff}.rimbo-toast-action-btn:hover{background:rgba(255,255,255,.1)}.rimbo-toast-tip{background:linear-gradient(135deg,#2c2c2c 0,#3a2f47 100%)}}.rimbo-toast-force-top{z-index:9999999!important}.rimbo-toast-with-progress::after{content:'';position:absolute;bottom:0;left:0;height:3px;background:currentColor;opacity:.3;animation:shrinkProgress 5s linear forwards}@keyframes shrinkProgress{from{width:100%}to{width:0%}}.participation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .3s ease}.participation-modal-overlay.show{display:flex}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.participation-modal{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:slideUp .3s ease;position:relative}@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.participation-modal-header{background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff;padding:20px 25px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center}.participation-modal-title{font-size:20px;font-weight:600;margin:0}.participation-modal-close{background:0 0;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.participation-modal-close:hover{background:rgba(255,255,255,.2)}.participation-modal-body{padding:25px}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.form-label.required::after{content:'*';color:#e74c3c;margin-left:4px}.form-input{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:8px;font-size:15px;transition:all .3s ease;background:#fff;box-sizing:border-box}.form-input:focus{outline:0;border-color:#27ae60;box-shadow:0 0 0 3px rgba(39,174,96,.1)}.form-input:invalid{border-color:#e74c3c}.form-select{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:8px;font-size:15px;background:#fff;cursor:pointer;transition:all .3s ease}.form-select:focus{outline:0;border-color:#27ae60;box-shadow:0 0 0 3px rgba(39,174,96,.1)}.form-textarea{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:8px;font-size:15px;resize:vertical;min-height:80px;max-height:120px;font-family:inherit;transition:all .3s ease}.form-textarea:focus{outline:0;border-color:#27ae60;box-shadow:0 0 0 3px rgba(39,174,96,.1)}.char-counter{text-align:right;font-size:12px;color:#666;margin-top:5px}.char-counter.warning{color:#e67e22}.char-counter.danger{color:#e74c3c}.currency-group{position:relative}.currency-symbol{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#666;font-weight:600;pointer-events:none}.currency-input{padding-left:32px!important}.optional-help{font-size:12px;color:#666;margin-top:5px;font-style:italic}.participation-modal-footer{padding:20px 25px;border-top:1px solid #e1e8ed;display:flex;gap:15px;justify-content:flex-end}.btn-modal{padding:12px 24px;border:none;border-radius:8px;font-weight:600;font-size:15px;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.btn-primary-modal{background:linear-gradient(135deg,#27ae60 0,#2ecc71 100%);color:#fff}.btn-primary-modal:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(39,174,96,.3)}.btn-secondary-modal{background:#6c757d;color:#fff}.btn-secondary-modal:hover{background:#5a6268;transform:translateY(-1px)}.form-loading{opacity:.6;pointer-events:none}.loading-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top:3px solid #fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.success-message{background:#d4edda;color:#155724;padding:15px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.search-results{max-height:250px;overflow-y:auto;margin-top:10px}.search-results-list{border:1px solid #e1e8ed;border-radius:8px;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,.1)}.search-result-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f1f1f1;transition:all .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#f8fff9;border-left:4px solid #27ae60}.search-result-item.search-result-expired{background:#fdf6f0;border-left:4px solid #f39c12}.search-result-item.search-result-expired:hover{background:#fcf1e8;border-left:4px solid #e67e22}.search-result-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.search-result-brand{font-weight:600;color:#27ae60;font-size:13px}.search-result-expired .search-result-brand{color:#e67e22}.search-result-title{font-size:14px;color:#333;margin-bottom:4px}.search-result-meta{font-size:12px;color:#666}.status-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#d4edda;color:#155724}.status-badge.expired{background:#fff3cd;color:#856404}.search-results-header{background:#f8f9fa;padding:8px 12px;border-bottom:1px solid #e1e8ed;font-size:12px;color:#666;text-align:center}.search-error,.search-no-results{padding:16px;text-align:center;color:#666;font-style:italic;border:1px solid #e1e8ed;border-radius:8px;background:#f9f9f9}.search-help{margin-top:5px}.search-help small{color:#666;font-size:12px}.selected-offer{background:#d4edda;border:1px solid #27ae60;border-radius:8px;padding:12px;margin-bottom:15px}.selected-offer-info{display:flex;justify-content:space-between;align-items:center}.selected-offer-text{font-weight:600;color:#155724;flex:1}.clear-selection{background:0 0;border:none;font-size:18px;color:#155724;cursor:pointer;padding:0 5px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.clear-selection:hover{background:rgba(21,87,36,.1)}.btn-manual-toggle{width:100%;padding:10px 16px;border:2px dashed #bdc3c7;border-radius:8px;background:#fff;color:#7f8c8d;cursor:pointer;font-size:14px;transition:all .3s ease}.btn-manual-toggle:hover{border-color:#27ae60;color:#27ae60;background:#f8fff9}@media (max-width:600px){.participation-modal{width:95%;margin:20px}.participation-modal-header{padding:15px 20px}.participation-modal-body{padding:20px}.participation-modal-footer{padding:15px 20px;flex-direction:column}.btn-modal{justify-content:center}.search-results{max-height:150px}}.dettaglio-container{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin:2rem auto}.dettaglio-container .card{display:block!important;flex-direction:column!important}.dettaglio-container .card-body{padding:1.5rem}.hero-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));padding:7.5rem 2rem .8rem 1rem;color:#fff}.hero-overlay .offer-title{font-size:1.8rem;margin-bottom:0!important;margin-top:0!important;text-shadow:0 2px 4px rgba(0,0,0,.5);line-height:1.2;position:relative;top:.8rem;left:.5rem}.offer-description{line-height:1.3!important}.offer-hero-image{width:100%;height:300px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));position:relative;overflow:hidden;border-radius:12px 12px 0 0}.offer-hero-image>img.offer-image{width:100%;height:100%;object-fit:cover;object-position:center;opacity:1;transition:opacity .3s ease}.offer-hero-image>img.offer-image[data-lazy]{opacity:0}.offer-hero-image>img.offer-image[data-lazy].loaded{opacity:1}.offer-hero-image button img{width:35px;height:35px;max-width:35px;min-width:35px;object-fit:contain;flex-shrink:0}.offer-hero-image .share-btn-detail img{width:39px;height:39px;max-width:39px;min-width:39px}.modern-steps-list .step-card{display:flex;align-items:center;margin:.8rem 0;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 6px rgba(0,128,54,.08);border-left:3px solid var(--primary-color);position:relative;overflow:hidden;transition:all .3s ease}.modern-steps-list .step-card:hover{transform:translateX(5px);box-shadow:0 4px 16px rgba(0,128,54,.2)!important}.modern-steps-list .step-icon{font-size:1.8rem;margin-right:1rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:45px;height:45px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:50%;color:#fff;box-shadow:0 3px 8px rgba(0,128,54,.25);animation:iconPulse 2s infinite ease-in-out}.modern-steps-list .step-content{flex:1}.modern-steps-list .step-title{margin:0 0 .3rem 0;color:var(--primary-color);font-size:1.1rem;font-weight:600}.modern-steps-list .step-description{margin:0;color:var(--text-color);line-height:1.4;font-size:.9rem}.modern-steps-list .step-number{font-size:1rem;color:var(--primary-color);font-weight:700;margin-left:.8rem;flex-shrink:0;width:26px;height:26px;background:rgba(0,128,54,.1);border-radius:50%;display:flex;align-items:center;justify-content:center}@keyframes iconPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.modern-steps-list .step-card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .6s}.modern-steps-list .step-card:hover::before{left:100%}.steps-list{display:none}.breadcrumbs{margin-bottom:2rem;font-size:.9rem}.breadcrumbs a{color:var(--primary-color);text-decoration:none}.breadcrumbs a:hover{text-decoration:underline}.products-list{background:#f8f9fa;padding:1rem;border-radius:8px;margin:1rem 0;border-left:4px solid #008036}.ean-products-details{border-top:1px solid #e9ecef}.ean-products-summary{cursor:pointer;color:#008036;font-weight:600;user-select:none;padding:.8rem;text-align:center;list-style:none;outline:0;transition:all .2s ease}.ean-products-summary:hover{background:rgba(0,128,54,.05);color:#006b2d}.ean-products-summary::-webkit-details-marker,.ean-products-summary::marker{display:none}.product-item{display:flex;align-items:center;margin:.5rem 0;padding:.5rem;background:#fff;border-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.contact-card{padding:1rem;background:#fff;border-radius:8px;border-left:4px solid #008036}.contact-card-whatsapp{border-left-color:#25d366}.contact-card h4{margin:0 0 .5rem 0;display:flex;align-items:center;gap:.5rem}.timing-info{background:rgba(255,193,7,.1);border-left:4px solid #ffc107;padding:1rem;border-radius:8px;margin-bottom:.75rem}.timing-grid{display:flex;gap:1.5rem;margin-bottom:1.5rem}.timing-grid-inner{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.products-ean-table .ean-code,.products-ean-table .product-name{min-width:0;word-wrap:break-word;overflow-wrap:break-word}.products-ean-table .product-name{font-size:.875rem}.detail-category-badge{color:#fff;padding:.4rem .8rem;border-radius:8px;font-size:.95rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;display:inline-flex;align-items:center;gap:4px;line-height:1;cursor:pointer;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;animation:subtlePulse 2.5s ease-in-out infinite;text-shadow:-.5px -.5px 0 rgba(0,0,0,.3),.5px -.5px 0 rgba(0,0,0,.3),-.5px .5px 0 rgba(0,0,0,.3),.5px .5px 0 rgba(0,0,0,.3)}.detail-category-badge::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .4s ease}.category-badge-link{text-decoration:none;display:inline-block;margin:0;padding:0;line-height:0}.category-badge-link:hover .detail-category-badge{transform:scale(1.05);box-shadow:0 6px 20px rgba(102,126,234,.5);opacity:1;animation:none}.category-badge-link:hover .detail-category-badge::before{left:100%}@keyframes subtlePulse{0%,100%{transform:scale(1);box-shadow:0 4px 15px rgba(0,0,0,.3);opacity:.82}50%{transform:scale(1.02);box-shadow:0 5px 18px rgba(102,126,234,.4);opacity:.92}}.offer-image-container .offer-badge{opacity:.88;text-shadow:-.5px -.5px 0 rgba(0,0,0,.3),.5px -.5px 0 rgba(0,0,0,.3),-.5px .5px 0 rgba(0,0,0,.3),.5px .5px 0 rgba(0,0,0,.3);transition:opacity .2s ease}.offer-image-container .offer-badge:hover{opacity:1}@media (max-width:768px){.dettaglio-container{grid-template-columns:1fr!important;gap:1rem}.timing-grid{flex-direction:column!important;gap:1rem!important}.timing-grid-inner{grid-template-columns:1fr!important}.modern-steps-list .step-card{flex-direction:column!important;text-align:center;padding:.8rem!important;margin:.6rem 0!important}.modern-steps-list .step-icon{margin:0 0 .6rem 0!important;align-self:center}.modern-steps-list .step-number{position:absolute!important;top:10px;right:10px;margin:0!important}.modern-steps-list .step-content{margin:0!important}.modern-steps-list .step-title{font-size:1rem!important}.modern-steps-list .step-description{font-size:.85rem!important}.participation-actions div[style*="display: flex"]{flex-direction:column!important;gap:.8rem!important}.participation-actions .btn{width:100%!important;max-width:300px}.products-ean-table .table-header{display:none!important}.products-ean-table .table-row{display:flex!important;flex-direction:column!important;gap:.5rem!important;padding:.7rem!important;margin-bottom:.6rem!important;background:#f8f9fa!important;border-radius:6px!important;border:1px solid #e9ecef!important;border-left:3px solid var(--primary-color)!important}.products-ean-table .product-name{font-size:.95rem!important;font-weight:600!important;color:var(--primary-color)!important;padding-bottom:.3rem!important;border-bottom:1px solid #e9ecef!important;line-height:1.3!important}.products-ean-table .regulation-variant{text-align:center!important;margin:.15rem 0!important}.products-ean-table .ean-code{text-align:left!important;font-size:.8rem!important;padding:.4rem!important;background:#fff!important;border:2px dashed var(--primary-color)!important;border-radius:4px!important;max-width:100%!important;overflow-x:auto!important;white-space:nowrap!important;-webkit-overflow-scrolling:touch!important}.products-ean-table .actions{display:flex!important;justify-content:center!important;gap:.5rem!important;padding-top:.2rem!important}.products-ean-table .actions a{padding:.5rem .7rem!important;min-width:80px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.3rem!important;font-size:.85rem!important}.products-ean-table .actions a svg{width:16px!important;height:16px!important}.scanner-controls{flex-direction:column!important;gap:.75rem!important}.scanner-controls button,.scanner-controls input{width:100%!important;max-width:none!important}.scanner-controls button{padding:.75rem 1rem!important;font-size:1rem!important}}@media (max-width:480px){.modern-steps-list .step-card{margin:.5rem 0!important;padding:.7rem!important}.modern-steps-list .step-icon{width:38px!important;height:38px!important;font-size:1.5rem!important}.modern-steps-list .step-number{width:22px!important;height:22px!important;font-size:.9rem!important}.participation-actions .btn{font-size:1rem!important;padding:.8rem 1.5rem!important}.products-ean-table .table-row{padding:.6rem!important;gap:.4rem!important;margin-bottom:.5rem!important}.products-ean-table .product-name{font-size:.9rem!important;padding-bottom:.25rem!important}.products-ean-table .ean-code{font-size:.75rem!important;padding:.35rem!important}.products-ean-table .actions{gap:.4rem!important;padding-top:.15rem!important}.products-ean-table .actions a{padding:.45rem .6rem!important;min-width:70px!important;font-size:.8rem!important}.products-ean-table .actions a svg{width:14px!important;height:14px!important}}.scanner-container{background:#fff;border-radius:var(--border-radius);padding:1rem;text-align:center;box-shadow:var(--box-shadow);margin:2rem 0 .5rem 0}#scanner-video{max-width:100%;border-radius:var(--border-radius);margin:1rem 0}.loading-placeholder{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}100%{background-position:-200% 0}}.sidebar-section{background:var(--background-color);padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-light);transition:var(--transition-base)}.sidebar-section:hover{border-color:var(--brand-primary-light);box-shadow:var(--shadow-sm)}.sidebar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-color);margin:0 0 var(--spacing-md) 0;display:flex;align-items:center;gap:var(--spacing-sm);line-height:1.2}.active-filters-section{background:linear-gradient(135deg,var(--brand-green-light) 0,var(--brand-primary-light) 100%);border:2px solid var(--brand-primary);border-radius:var(--border-radius-lg);padding:var(--spacing-md);animation:slideInDown .3s ease-out}@keyframes slideInDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes badgePulse{0%{transform:scale(1)}50%{transform:scale(1.3);box-shadow:0 0 20px rgba(76,175,80,.6)}100%{transform:scale(1)}}.active-filters-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--brand-primary-dark);margin:0 0 var(--spacing-sm) 0;line-height:1.2}.active-filters-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.active-filter{background:var(--brand-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);display:flex;justify-content:space-between;align-items:center;transition:var(--transition-fast)}.active-filter.brand-filter{background:var(--brand-secondary)}.clear-filter{background:rgba(255,255,255,.3);border:none;color:#fff;border-radius:var(--border-radius-full);width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);transition:var(--transition-fast)}.clear-filter:hover{background:rgba(255,255,255,.5);transform:scale(1.1)}.clear-all-container{text-align:center;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid rgba(255,255,255,.2)}.clear-all-link{color:var(--brand-primary-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:var(--transition-fast)}.clear-all-link:hover{color:var(--brand-primary);text-decoration:underline}.search-container{position:relative}.search-input{width:100%;padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;color:#374151;background:#fff;transition:all .2s ease}.search-input:focus{outline:0;border-color:var(--brand-primary);box-shadow:0 0 0 3px var(--brand-primary-light);background:#fff}.search-input::placeholder{color:var(--text-muted);font-style:italic}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);max-height:200px;overflow-y:auto;z-index:100;margin-top:2px}.suggestion-item{padding:var(--spacing-sm) var(--spacing-md);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:var(--transition-fast);border-bottom:1px solid var(--border-light)}.suggestion-item:hover{background:var(--brand-primary-light);color:var(--brand-primary-dark)}.suggestion-item:last-child{border-bottom:none}.brand-name{font-weight:var(--font-weight-medium);color:var(--text-color)}.offer-count{font-size:var(--font-size-sm);color:var(--text-muted);background:var(--neutral-100);padding:2px 6px;border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium)}.current-search-info{background:var(--success-light);color:var(--success-dark);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);margin-top:var(--spacing-sm);border:1px solid var(--success)}.category-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.category-btn{width:100%;padding:var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--border-radius-md);background:var(--background-color);color:var(--text-color);font-family:var(--font-family-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-base);display:flex;align-items:center;gap:var(--spacing-md);text-align:left}.category-btn:hover{background:var(--brand-primary-light);border-color:var(--brand-primary);color:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.category-btn:active{transform:translateY(0)}.category-btn.active{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff;box-shadow:var(--shadow-md)}.category-btn.active:hover{background:var(--brand-primary-dark);border-color:var(--brand-primary-dark)}.category-btn.reset-btn{background:var(--neutral-100);border-color:var(--neutral-300);color:var(--text-muted)}.category-btn.reset-btn:hover{background:var(--neutral-200);border-color:var(--neutral-400);color:var(--text-color)}.category-btn.reset-btn.active{background:var(--neutral-600);border-color:var(--neutral-600);color:#fff}.category-icon{font-size:1.5em;width:32px;min-width:32px;text-align:center;flex-shrink:0}.category-info{flex:1;display:flex;justify-content:space-between;align-items:center}.category-name{font-weight:var(--font-weight-semibold)}.category-count{background:rgba(255,255,255,.2);padding:2px 8px;border-radius:var(--border-radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);min-width:30px;text-align:center}.category-btn.active .category-count{background:rgba(255,255,255,.3)}.category-btn:not(.active) .category-count{background:var(--neutral-200);color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.stat-item{text-align:center;padding:var(--spacing-md);background:var(--neutral-50);border-radius:var(--border-radius-md);border:1px solid var(--border-light);transition:var(--transition-base)}.stat-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.stat-item.primary{background:var(--brand-primary-light);border-color:var(--brand-primary)}.stat-item.secondary{background:var(--brand-secondary-light);border-color:var(--brand-secondary)}.stat-item.highlight{background:var(--success-light);border-color:var(--success)}.stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--brand-primary);line-height:1.2;margin-bottom:var(--spacing-xs)}.stat-item.secondary .stat-value{color:var(--brand-secondary)}.stat-item.highlight .stat-value{color:var(--success-dark)}.stat-label{font-size:var(--font-size-sm);color:var(--text-muted);font-weight:var(--font-weight-medium);line-height:1.2}.newsletter-section{background:linear-gradient(135deg,#f0f9ff 0,#e0f2fe 100%);border:2px solid #0ea5e9}.newsletter-text{color:#0369a1;font-size:14px;margin:8px 0 16px 0;text-align:center}.newsletter-form{display:flex;flex-direction:column;gap:12px}.newsletter-input{width:100%;padding:12px 16px;border:2px solid #0ea5e9;border-radius:8px;font-size:14px;background:#fff;color:#374151;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif}.newsletter-input:focus{outline:0;border-color:#0284c7;box-shadow:0 0 0 3px rgba(14,165,233,.1)}.btn-newsletter{background:#0ea5e9;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif}.btn-newsletter:hover{background:#0284c7;transform:translateY(-1px)}@media (max-width:1024px){.stats-grid{grid-template-columns:1fr;gap:var(--spacing-xs)}}@media (max-width:768px){.category-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.category-btn{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.category-icon{font-size:1.2em;min-width:24px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs)}.stat-item{padding:var(--spacing-sm)}.stat-value{font-size:var(--font-size-lg)}.search-suggestions{position:fixed;top:auto;left:var(--spacing-md);right:var(--spacing-md);z-index:1000}}@media (max-width:480px){.sidebar-section{padding:var(--spacing-sm)}.category-buttons{grid-template-columns:1fr}.category-btn{padding:var(--spacing-sm) var(--spacing-md)}.category-btn .category-count{display:none}.stats-grid{grid-template-columns:1fr 1fr}.active-filters-container{gap:var(--spacing-xs)}.active-filter{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}}.category-btn:focus,.clear-all-link:focus,.clear-filter:focus,.search-input:focus{outline:2px solid var(--brand-primary);outline-offset:2px}@media (prefers-contrast:high){.category-btn{border-width:3px}.active-filter{border:2px solid var(--background-color)}}@media (prefers-color-scheme:dark){.sidebar-section{background:var(--background-color-dark,#222);border-color:var(--border-light-dark,#333)}.search-input{background:var(--background-color-dark,#222);color:var(--text-color-dark,#e0e0e0);border-color:var(--border-color-dark,#333)}.category-btn{background:var(--background-color-dark,#222);color:var(--text-color-dark,#e0e0e0);border-color:var(--border-color-dark,#333)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.pagination-container{margin:1.5rem auto;padding:0 .5rem;max-width:900px;text-align:center;background:linear-gradient(135deg,#f8f9fa 0,#e9ecef 100%);border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.06);border:1px solid rgba(0,128,0,.1)}.pagination-wrapper{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem .5rem;flex-wrap:wrap}.pagination-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .9rem;background:linear-gradient(145deg,#28a745,#20c997);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.85rem;transition:all .3s cubic-bezier(.4, 0, .2, 1);border:2px solid transparent;box-shadow:0 1px 6px rgba(40,167,69,.25);position:relative;overflow:hidden}.pagination-btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.pagination-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(40,167,69,.4);background:linear-gradient(145deg,#20c997,#17a2b8);border-color:rgba(255,255,255,.3)}.pagination-btn:hover::before{left:100%}.pagination-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(40,167,69,.3)}.pagination-numbers{display:flex;align-items:center;gap:.25rem;margin:0 .5rem;flex-wrap:wrap;justify-content:center}.pagination-number{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 .4rem;text-decoration:none;color:#495057;font-weight:600;font-size:.85rem;border-radius:8px;transition:all .2s ease;background:#fff;border:2px solid #e9ecef;position:relative}.pagination-number:hover{background:linear-gradient(145deg,#e9ecef,#f8f9fa);border-color:#28a745;color:#28a745;transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.pagination-current{background:linear-gradient(145deg,#28a745,#20c997)!important;color:#fff!important;border-color:#28a745!important;box-shadow:0 3px 12px rgba(40,167,69,.4);transform:scale(1.1);font-weight:700}.pagination-current:hover{transform:scale(1.1) translateY(-1px)}.pagination-dots{color:#6c757d;font-weight:700;font-size:1.2rem;padding:0 .5rem;display:inline-flex;align-items:center}.pagination-separator{color:#6c757d;font-size:1rem;font-weight:700;padding:0 .5rem;display:inline-flex;align-items:center}.pagination-stats{color:#6c757d;font-size:.8rem;font-weight:500;display:inline-flex;align-items:center;white-space:nowrap}@media (max-width:768px){.pagination-container{margin:1rem .25rem;border-radius:10px}.pagination-wrapper{padding:.6rem .25rem;gap:.3rem}.pagination-btn{padding:.4rem .7rem;font-size:.8rem}.pagination-btn .pagination-text{display:none}.pagination-number{min-width:28px;height:28px;font-size:.75rem}.pagination-numbers{margin:0 .3rem}.pagination-separator{padding:0 .3rem;font-size:.9rem}.pagination-stats{font-size:.7rem}}@media (max-width:480px){.pagination-container{margin:1rem .25rem}.pagination-wrapper{padding:.5rem .25rem;gap:.25rem}.pagination-btn{padding:.35rem .6rem;gap:.2rem}.pagination-number{min-width:26px;height:26px;font-size:.7rem}.pagination-numbers{margin:0 .25rem}.pagination-separator{padding:0 .2rem}.pagination-stats{font-size:.65rem}}@keyframes pageLoad{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pagination-container{animation:pageLoad .5s ease-out}.pagination-number{transition:all .2s cubic-bezier(.4, 0, .2, 1)}.pagination-current::after{content:'';position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#28a745,#20c997,#17a2b8,#28a745);border-radius:12px;z-index:-1;animation:borderGlow 2s linear infinite;background-size:300% 300%}@keyframes borderGlow{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}@media (prefers-color-scheme:dark){.pagination-container{background:linear-gradient(135deg,#2d3748 0,#4a5568 100%);border-color:rgba(255,255,255,.1)}.pagination-number{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.pagination-number:hover{background:#4a5568;color:#f7fafc}.pagination-stats{background:rgba(45,55,72,.7);color:#e2e8f0;border-color:rgba(255,255,255,.1)}.pagination-dots{color:#a0aec0}}:root{--pagination-primary:#28a745;--pagination-secondary:#20c997;--pagination-accent:#17a2b8;--pagination-success:#28a745;--pagination-warning:#ffc107}.pagination-btn:focus,.pagination-number:focus{outline:3px solid rgba(40,167,69,.5);outline-offset:2px}.pagination-current{aria-current:page}@media print{.pagination-container{display:none}}.lazy-placeholder-skeleton{position:relative;background:linear-gradient(135deg,#f8f9fa 0,#e9ecef 100%);border-radius:12px;overflow:hidden;min-height:200px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:opacity .3s ease}.skeleton-animation{width:100%;padding:1.5rem;position:relative}.skeleton-line{height:12px;background:linear-gradient(90deg,#e9ecef 25%,#f8f9fa 50%,#e9ecef 75%);background-size:200% 100%;border-radius:6px;margin-bottom:.75rem;animation:skeletonShimmer 1.5s infinite}.skeleton-title{height:16px;width:70%;margin-bottom:1rem}.skeleton-subtitle{height:12px;width:50%;margin-bottom:1.5rem}.skeleton-box{height:120px;width:100%;border-radius:8px;margin-bottom:0}@keyframes skeletonShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.lazy-placeholder{filter:blur(5px);transition:filter .3s ease}.lazy-loading{position:relative}.lazy-loading::after{content:'';position:absolute;top:50%;left:50%;width:24px;height:24px;margin:-12px 0 0 -12px;border:2px solid rgba(40,167,69,.3);border-radius:50%;border-top-color:#28a745;animation:spin 1s ease-in-out infinite;z-index:10}.lazy-loaded{filter:none;opacity:1!important}.lazy-error{filter:grayscale(100%);opacity:.5}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:768px){.lazy-placeholder-skeleton{min-height:150px}.skeleton-animation{padding:1rem}.skeleton-box{height:80px}}@media (max-width:480px){.lazy-placeholder-skeleton{min-height:120px;border-radius:8px}.skeleton-animation{padding:.75rem}.skeleton-line{height:10px;margin-bottom:.5rem}.skeleton-title{height:14px;margin-bottom:.75rem}.skeleton-box{height:60px}}@media (prefers-color-scheme:dark){.lazy-placeholder-skeleton{background:linear-gradient(135deg,#2d3748 0,#4a5568 100%)}.skeleton-line{background:linear-gradient(90deg,#4a5568 25%,#2d3748 50%,#4a5568 75%);background-size:200% 100%}}@media (prefers-reduced-motion:reduce){.lazy-loading::after,.skeleton-line{animation:none}.skeleton-line{background:#e9ecef}}@media print{.lazy-loading::after,.lazy-placeholder-skeleton{display:none}}.layout-container,.main-container{display:flex;max-width:var(--layout-max-width,1400px);margin:0 auto;gap:var(--content-gap,20px);padding:var(--container-padding,20px);min-height:calc(100vh - 120px)}.sidebar,.sidebar-unified,aside{width:var(--sidebar-width,300px)!important;max-width:var(--sidebar-width,300px)!important;min-width:var(--sidebar-width,300px);flex-shrink:0;position:sticky;top:20px;max-height:calc(100vh - 40px);overflow-y:auto;overflow-x:hidden}.content,.main-content,main{flex:1;min-width:0;max-width:calc(100% - var(--sidebar-width,300px) - var(--content-gap,20px))}@media (max-width:1200px){.sidebar,.sidebar-unified,aside{width:280px!important;max-width:280px!important;min-width:280px}.content,.main-content,main{max-width:calc(100% - 280px - var(--content-gap,20px))}}@media (max-width:968px){.layout-container,.main-container{flex-direction:column;gap:var(--space-4,1rem)}.sidebar,.sidebar-unified,aside{width:100%!important;max-width:100%!important;min-width:auto;position:static;max-height:none;order:2}.content,.main-content,main{max-width:100%;order:1}}@media (min-width:969px){.layout-container,.main-container{flex-direction:row!important}.sidebar,.sidebar-unified,aside{width:var(--sidebar-width,300px)!important;max-width:var(--sidebar-width,300px)!important;position:sticky!important;order:initial!important}.content,.main-content,main{flex:1!important;order:initial!important}}@supports not (selector(var(--sidebar-width))){.sidebar,.sidebar-unified,aside{width:300px!important;max-width:300px!important}}.layout-debug .sidebar{border:3px solid #27ae60!important;background:rgba(39,174,96,.05)!important}.layout-debug .content{border:3px solid #e74c3c!important;background:rgba(231,76,60,.05)!important}.action-btn,.barcode-scanner-btn,.btn,.category-btn,.nav-link,.scanner-btn,button:not(.mobile-menu-toggle){min-height:44px!important;min-width:44px;padding:12px 16px;touch-action:manipulation}input:not(.global-search-input),select,textarea{min-height:44px!important;font-size:16px!important;padding:12px}a{min-height:32px;display:inline-block;padding:8px}.card,.offer-card{padding:16px;margin:12px 0}.barcode-scanner-btn{min-height:48px!important;min-width:48px!important;font-size:18px}@media print{.sidebar,.sidebar-unified,aside{display:none}.content,.main-content,main{max-width:100%!important}}.logo-text{font-weight:700!important;background:linear-gradient(135deg,var(--brand-green-dark) 0,var(--brand-green) 100%)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important;color:var(--brand-green-dark)!important;font-size:24px;font-family:var(--font-primary);letter-spacing:-.5px;line-height:1}.navbar-brand .logo{color:inherit!important;background:inherit!important;font-weight:inherit!important}:root{--primary-color:var(--brand-green);--secondary-color:var(--brand-green-light);--dark-green:var(--brand-green-dark);--light-gray:var(--gray-100);--dark-gray:var(--gray-800);--text-color:var(--gray-800);--background-color:var(--gray-50);--success:var(--brand-green);--warning:var(--brand-accent);--info:#3498db;--danger:#e74c3c}.navbar-unified{z-index:var(--z-navbar)!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(255,255,255,.98)!important}.action-badge,span#favoritesCount.action-badge{position:absolute!important;top:-4px!important;right:-4px!important;background:linear-gradient(135deg,#e74c3c 0,#c0392b 100%)!important;color:#fff!important;font-size:11px!important;font-weight:700!important;padding:3px 7px!important;border-radius:12px!important;min-width:20px!important;text-align:center!important;box-shadow:0 2px 6px rgba(231,76,60,.3)!important;animation:badgePulse 2s infinite;display:inline-block!important;line-height:1.2!important;width:auto!important;height:auto!important;flex:none!important;transform:none!important}.action-badge.hidden{display:none!important}@keyframes badgePulse{0%{transform:scale(1)}50%{transform:scale(1.05)}100%{transform:scale(1)}}.btn-login,.btn-primary{background:linear-gradient(135deg,var(--brand-green) 0,var(--brand-green-light) 100%)!important;color:#fff!important;border:none!important;transition:all .3s var(--transition-smooth)}.btn-login:hover,.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(39,174,96,.3)}input:not(.global-search-input),select,textarea{font-family:var(--font-primary)!important;border-radius:var(--radius-md)!important;border:2px solid var(--gray-200)!important;transition:border-color var(--transition-fast)!important}input:not(.global-search-input):focus,select:focus,textarea:focus{border-color:var(--brand-green)!important;outline:0!important;box-shadow:0 0 0 3px rgba(39,174,96,.1)!important}@media (max-width:768px){.logo-text{font-size:16px!important}.navbar-container{padding:0 4px!important;gap:4px!important}}@media (max-width:480px){.logo-text{font-size:16px!important}}.navbar-unified *{transform:translateZ(0);will-change:transform}.action-btn,.nav-link{will-change:transform,background-color}.action-btn:focus,.btn-login:focus,.nav-link:focus{outline:2px solid var(--brand-green)!important;outline-offset:2px!important}@media (prefers-contrast:high){.logo-text{color:var(--brand-green-dark)!important;background:0 0!important;-webkit-text-fill-color:var(--brand-green-dark)!important}.navbar-unified{border-bottom:3px solid var(--brand-green)!important}}@media (prefers-reduced-motion:reduce){.action-badge{animation:none!important}.action-btn,.btn-login,.nav-link{transition:none!important}}@media print{.navbar-unified{position:relative!important;box-shadow:none!important;background:#fff!important;border-bottom:2px solid #000!important}.logo-text{color:#000!important;background:0 0!important;-webkit-text-fill-color:initial!important}.mobile-menu-toggle,.navbar-actions{display:none!important}}