html,body{height:100%;margin:0;padding:0;background-color:#f7f2e7;color:#663e3e;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{min-width:320px}main{max-width:900px;margin-top:.5rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;padding:1rem;background-color:#d7e3c4;border-radius:16px;box-shadow:0 6px 15px #3c321e26;color:#4a5d23}.banner-inferior{position:fixed;left:0;width:100%;background-color:#2b2b28d9;color:#fff;z-index:1000;box-shadow:0 -2px 6px #b39e9e4d}.banner-bottom{bottom:0}.banner-top{top:0;box-shadow:0 2px 6px #b39e9e4d}.banner-contenido{display:flex;align-items:center;justify-content:center;gap:12px;text-decoration:none;color:#fff;min-height:70px;cursor:pointer;transition:opacity .3s ease-in-out}.fade-in{opacity:1}.fade-out{opacity:0}.banner-media{flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:8px;overflow:hidden}.banner-media img,.banner-media video{width:100%;height:100%;object-fit:cover}.banner-texto{font-size:1rem;font-weight:700;flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.banner-loading{text-align:center;min-height:70px}html,body{margin:0;padding:45px 0 0}.app-header{position:fixed;top:0;left:0;right:0;height:45px;background-color:#4a5d23;max-width:900px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #4a5d2399;z-index:1000;color:#f7f2e7}.submenu-mercado-button{font-size:1rem;background-color:transparent;border:2px solid #d7e3c4;border-radius:6px;color:#f7f2e7;padding:.3rem .7rem;cursor:pointer;transition:background-color .2s ease,color .2s ease}.submenu-mercado-button:hover,.submenu-mercado-button:focus{background-color:#d7e3c4;color:#4a5d23;outline:none}.menu-button{font-size:1.8rem;background:none;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;color:#f7f2e7;padding:0 .5rem;transition:color .3s ease}.menu-button:hover,.menu-button:focus{color:#d7e3c4;outline:none}.menu-dropdown{position:absolute;top:110%;right:1rem;background:#f7f2e7;border:1px solid #7c9a57;border-radius:8px;box-shadow:0 4px 12px #7c9a5766;display:flex;flex-direction:column;min-width:160px;z-index:1100}.menu-dropdown button{padding:.75rem 1rem;background:none;border:none;text-align:left;width:100%;cursor:pointer;font-size:1rem;color:#4a5d23;font-weight:600;transition:background-color .2s ease,color .2s ease;border-radius:4px}.menu-dropdown button:hover:not(:disabled),.menu-dropdown button:focus:not(:disabled){background-color:#7c9a57;color:#f7f2e7;outline:none}.menu-dropdown button:disabled{color:#999;cursor:default}@media (min-width: 601px){.menu-button{display:block}}.login-card{background:#f7f2e7;padding:2rem;border-radius:16px;box-shadow:0 6px 15px #3c321e33;max-width:420px;margin:2rem auto;color:#3e3e2e;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.login-card h2{text-align:center;font-size:1.8rem;margin-bottom:.5rem;color:#3e6641;font-family:Palatino Linotype,serif;text-shadow:1px 1px 3px rgba(0,0,0,.1)}.login-subtext{text-align:center;color:#5a5a3f;font-style:italic;margin-bottom:.25rem}.login-note{text-align:center;font-size:.95rem;color:#6b6b4d;margin-bottom:1.5rem}.login-card form{display:flex;flex-direction:column;gap:1rem}.login-card button{padding:.75rem;border:none;background-color:#7c9a57;color:#fff;font-weight:700;border-radius:8px;cursor:pointer;transition:background-color .3s ease,transform .2s ease;font-size:1rem;box-shadow:0 4px 10px #7c9a5766}.login-card button:hover{background-color:#678444;transform:scale(1.03)}.login-card .google-btn{background-color:#db4437}.login-card .google-btn:hover{background-color:#c33c2f}.error-msg{color:#d14343;font-weight:700;text-align:center;margin-top:1rem}@media (max-width: 480px){.login-card{padding:1.5rem 1rem}.login-card h2{font-size:1.5rem}.login-card button{font-size:.95rem}}.admin-panel{background:#2c2c2c;padding:2rem;border-radius:12px;box-shadow:0 0 15px #000;max-width:400px;margin:2rem auto;color:#fff;width:90%;text-align:center}.admin-panel h2{font-size:1.75rem;margin-bottom:1rem}.admin-panel p{font-size:1.1rem;margin-bottom:1.5rem}.admin-panel button{padding:.75rem 1.5rem;font-size:1rem;font-weight:700;background-color:#646cff;color:#fff;border:none;border-radius:8px;cursor:pointer}.admin-panel button:hover{background-color:#535bf2}@media (max-width: 480px){.admin-panel{padding:1.5rem 1rem}.admin-panel h2{font-size:1.5rem}.admin-panel p,.admin-panel button{font-size:.95rem}}.login-button{background:transparent;color:#4a6b2f;border:2px solid #7c9a57;border-radius:12px;padding:.1rem .5rem;cursor:pointer;font-weight:600;font-size:1rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:background-color .25s ease,color .25s ease,box-shadow .25s ease;text-decoration:none;display:inline-block;vertical-align:middle}.login-button:hover,.login-button:focus{background-color:#7c9a57;color:#f7f2e7;box-shadow:0 0 8px #7c9a57aa;outline:none}.login-button:active{background-color:#5d753d;box-shadow:none;transform:scale(.97)}.container{max-width:450px;margin:1rem auto;text-align:center;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;padding:.1rem 1rem;background-color:#f7f2e7;border-radius:16px;box-shadow:0 6px 15px #3c321e33}.container h1{margin-bottom:.5rem;color:#3e6641;font-weight:700;font-family:Palatino Linotype,serif;text-shadow:1px 1px 3px rgba(0,0,0,.1)}.container p{margin-bottom:2rem;color:#5a5a3f;font-size:1.1rem;line-height:1.5;font-style:italic}.option-card{border:2px solid #7c9a57;border-radius:12px;box-shadow:0 5px 12px #7c9a574d;margin-bottom:2rem;overflow:hidden;cursor:pointer;background-color:#d7e3c4;transition:transform .25s ease,box-shadow .25s ease}.option-card:hover{transform:scale(1.07);box-shadow:0 8px 20px #7c9a5799}.option-card img{width:100%;height:180px;object-fit:cover;filter:brightness(.9)}.option-card h2{margin:0 0 .5rem;color:#4a5d23;font-family:Georgia,serif}.option-card p{margin:0;color:#556b2f;font-size:.95rem;font-weight:500}.option-card.disabled{filter:grayscale(100%) brightness(.85);opacity:.6;cursor:pointer}.option-card.disabled:hover{transform:scale(1.05);box-shadow:0 6px 15px #7c9a5766}.coming-soon{color:#999;font-size:.85rem;font-style:italic;margin-top:.5rem}.landing-container{max-width:900px;margin:2rem auto;color:#333;padding:0 1rem;text-align:center}.landing-container h1{font-size:2.5rem;margin-bottom:1rem;color:#7f1212}.landing-container p{font-size:1.2rem;line-height:1.6;margin-bottom:2rem;color:#555}.vitrina-carousel-container{position:relative;margin-bottom:2rem;overflow:hidden}.vitrina-carousel{display:flex;gap:1rem;scroll-snap-type:x mandatory;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.vitrina-carousel::-webkit-scrollbar{display:none}.vitrina-item{flex:0 0 90%;scroll-snap-align:center;background:#fff;border-radius:12px;box-shadow:0 6px 15px #0000001a;padding:1rem;text-align:center}.vitrina-item img{width:100%;height:auto;border-radius:10px;margin-bottom:1rem;aspect-ratio:16 / 9;object-fit:cover}.vitrina-item p{font-size:1.1rem;color:#444;font-style:italic;padding:0 1rem}.scroll-hint{text-align:center;font-size:.9rem;color:#999;margin-top:-1rem;animation:parpadeo 1.8s infinite ease-in-out}@keyframes parpadeo{0%,to{opacity:1}50%{opacity:.3}}.products-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}@media (max-width: 480px){.landing-container{padding:0 .5rem}.products-grid{grid-template-columns:repeat(2,1fr)}}.product-card{cursor:pointer;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000001a;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s ease}.product-card:hover,.product-card:focus{box-shadow:0 4px 10px #0003;outline:none}.product-card img{width:100%;object-fit:cover;aspect-ratio:1 / 1}.product-card h3{padding:.5rem;font-size:1rem;color:#333;margin:0;text-align:center}.fullscreen-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#1b3a1a;z-index:9999;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto}.fullscreen-modal-content{width:100%;height:100%;padding:2rem;box-sizing:border-box;position:relative;background-color:#2e5e2e;color:#f4f0e6;font-family:Segoe UI,sans-serif;background-size:contain}.fullscreen-modal-close{position:absolute;top:15px;right:20px;font-size:2rem;background:none;border:none;color:#f4f0e6;cursor:pointer;z-index:10000}.fullscreen-modal-close:hover{color:#ffe600}.modal-body{max-width:800px;margin:4rem auto 2rem;text-align:center}.modal-product-image{width:100%;max-height:400px;object-fit:contain;border-radius:8px;margin-bottom:1rem;cursor:zoom-in;background-color:#a3cbb0;border:3px solid #c68c53}.modal-description{font-size:1rem;color:#ffe;margin-top:.5rem}.modal-buttons{margin-top:1.5rem}.option-button{background-color:#ffa726;border:none;color:#1b1b1b;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:700;font-size:1rem;transition:background-color .2s ease}.option-button:hover{background-color:#fb8c00}.carousel-container{position:relative}.carousel-thumbnails{display:flex;justify-content:center;margin-top:1rem;gap:.5rem;flex-wrap:wrap}.thumbnail{width:60px;height:60px;object-fit:cover;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:border-color .3s;background-color:#ccc}.thumbnail.active,.thumbnail:hover{border-color:#ffe600}.fullscreen-image-view{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000000e6;display:flex;justify-content:center;align-items:center;z-index:10000;cursor:zoom-out}.fullscreen-image-view img{max-width:90%;max-height:90%;border-radius:12px;border:3px solid #c68c53}.modal-specs{text-align:left;margin:1rem auto;max-width:500px}.modal-specs h4{margin-bottom:.5rem;color:#ffe}.modal-specs ul{list-style-type:disc;padding-left:1.2rem;color:#f0f0d0}.user-panel-wrapper{max-width:900px;margin:0 auto;padding:2rem 1rem;background-color:#e8f5e9}.products-title{font-size:1.8rem;margin-bottom:1.5rem;color:#2e7d32;font-weight:700;text-align:center}.products-grid{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.user-product-card{background-color:#fff;border-radius:12px;padding:1rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;border:2px solid #c8e6c9}.user-product-card:hover{transform:translateY(-3px);box-shadow:0 6px 15px #26462033}.user-product-image{width:100%;height:150px;object-fit:cover;border-radius:8px;margin-bottom:.75rem;background-color:#d0e8d0}.product-name{font-size:1.05rem;margin:.5rem 0;color:#1b5e20;font-weight:600}.product-price{font-size:1rem;font-weight:700;margin-bottom:.75rem;color:#ef6c00}.submenu-mercado{position:absolute;top:3.5rem;left:1rem;background-color:#fff;border:1px solid #ccc;border-radius:8px;padding:.5rem;z-index:1000;box-shadow:0 2px 6px #0003}.submenu-mercado button{display:block;width:100%;padding:.5rem;background:none;border:none;text-align:left;cursor:pointer}.submenu-mercado button:hover{background-color:#f0f0f0}
