@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700&family=Playfair+Display:wght@500;700&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Montserrat',sans-serif;background:#f0e7db;color:#2f2f2f}


header{background:#3B2F2F;position:sticky;top:0;z-index:1000}
nav{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 24px}
.logo{display:flex;align-items:center;gap:10px;color:#fff}
.logo img{width:46px;height:46px;object-fit:cover;border-radius:8px}
.logo span{font-size:22px;font-family:'Playfair Display',serif}
nav ul{list-style:none;display:flex;gap:22px;align-items:center}
nav ul li{position:relative}
nav a{text-decoration:none;color:#fff;transition:.2s}
nav a:hover{color:#D4AF37}
.submenu:hover .dropdown{display:block}
.dropdown{display:none;position:absolute;top:120%;left:0;background:#fff;border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.12);padding:10px;min-width:200px}
.dropdown li a{color:#3B2F2F;padding:8px 10px;display:block;border-radius:6px}
.dropdown li a:hover{background:#f5efe6}
.nav-icons a{color:#fff;margin-left:12px}


.banner{position:relative;height:clamp(320px,55vw,560px);overflow:hidden;background:#eee}
.banner>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:opacity .6s ease}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.45));pointer-events:none}
.banner-text{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:0 18px;z-index:1}
.banner-text h1{color:#fff;font-family:'Playfair Display',serif;font-weight:700;line-height:1.1;font-size:clamp(24px,4.4vw,48px);text-shadow:0 10px 24px rgba(0,0,0,.45);margin-bottom:14px}
.btn{display:inline-block;padding:12px 22px;border-radius:12px;color:#fff;text-decoration:none;font-weight:800;box-shadow:0 8px 22px rgba(0,0,0,.2)}
.btn:hover{filter:brightness(.95);transform:translateY(-1px)}
.btn-orange{background:#FF7F00}.btn-brown{background:#59351F}.btn-green{background:#2c7a5b}


.botones-categoria{padding:44px 16px;text-align:center;background:#fdf9f2}
.botones-categoria h2{font-size:2rem;margin-bottom:22px;color:#3B2F2F}
.categorias-circulares{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.categoria-item{width:150px;text-decoration:none;color:#2f2f2f}
.circle-img{width:130px;height:130px;border-radius:50%;overflow:hidden;margin:0 auto 10px;border:3px solid #c8a870;box-shadow:0 6px 16px rgba(0,0,0,.08)}
.circle-img img{width:100%;height:100%;object-fit:cover}


:root{--thumb-h:160px}
.categoria-scroll{margin:32px auto;width:min(96%,1200px)}
.categoria-scroll h2{font-weight:700;color:#3B2F2F;margin:0 0 12px 4px}
.scroll-contenedor{display:flex;gap:16px;padding:10px 6px;overflow-x:auto;scroll-snap-type:x mandatory}
.scroll-contenedor::-webkit-scrollbar{height:8px}
.scroll-contenedor::-webkit-scrollbar-thumb{background:#d2c2a5;border-radius:10px}
.scroll-contenedor .producto{flex:0 0 200px;max-width:200px;background:#fff;border-radius:12px;box-shadow:0 6px 14px rgba(0,0,0,.08);padding:12px;scroll-snap-align:start;text-align:center}
.scroll-contenedor .producto>a{display:block;color:inherit;text-decoration:none}
.scroll-contenedor .producto img{width:100%!important;height:var(--thumb-h)!important;object-fit:contain!important;background:#f7f3ef;border-radius:10px;display:block!important}
.scroll-contenedor .producto h4{font-size:.95rem;font-weight:600;color:#2f2f2f;margin:10px 6px 4px;line-height:1.25;height:2.5em;overflow:hidden}
.precio{display:inline-block;color:#59351F;font-weight:700;margin-bottom:2px}


.grid-wrap{max-width:1200px;margin:30px auto;padding:0 12px}
.productos-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.card-prod{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.08);padding:12px;width:210px;text-align:center}
.card-prod a{color:inherit;text-decoration:none;display:block}
.card-prod img{width:100%;height:180px;object-fit:contain;background:#faf7f3;border-radius:10px}
.card-prod h3{font-size:15px;margin:10px 0 6px;min-height:38px;line-height:1.2}
.stock-ok{color:#2c7a5b;font-size:12px;font-weight:600}
.stock-low{color:#b45309;font-size:12px;font-weight:600}
.stock-out{color:#b91c1c;font-size:12px;font-weight:700}

.formulario{max-width:420px;margin:50px auto;background:#fff;padding:28px;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.08);text-align:center}
.formulario h2{margin-bottom:12px}
.formulario input, .formulario select{width:100%;padding:12px;margin:8px 0;border:1px solid #ccc;border-radius:8px}
.formulario button{margin-top:6px}

.producto-detalle{display:flex;gap:28px;max-width:1100px;margin:40px auto;background:#fff;padding:24px;border-radius:12px;box-shadow:0 3px 10px rgba(0,0,0,.08)}
.producto-imagen img{width:360px;max-width:100%;height:auto;object-fit:contain;background:#f7f3ef;border-radius:10px}
.producto-info h1{font-size:26px;margin-bottom:6px}
.producto-info .precio{font-size:22px}
.cantidad-control{display:flex;align-items:center;gap:10px;margin:10px 0}

footer{text-align:center;background:#3B2F2F;color:#fff;padding:20px;margin-top:30px}


*{box-sizing:border-box}
img, svg, video{max-width:100%; height:auto; display:block}
html,body{margin:0; padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Montserrat,Arial,sans-serif;background:#f6efe7;color:#2b2b2b}


header{background:#3B2F2F; position:sticky; top:0; z-index:1000}
nav{max-width:1200px; margin:0 auto; display:flex; align-items:center; gap:14px; padding:10px 14px; color:#fff}
.logo{display:flex; align-items:center; gap:10px}
.logo img{width:42px; height:42px; object-fit:cover; border-radius:6px; background:#fff}
nav a{color:#fff; text-decoration:none}
.nav-icons a{margin-left:12px}


.nav-menu{list-style:none; display:flex; gap:22px; align-items:center; margin:0; padding:0}


.nav-toggle{display:none; background:transparent; border:0; color:#fff; font-size:22px; padding:8px; cursor:pointer}


.submenu{position:relative}
.submenu > .dropdown{
  position:absolute; top:100%; left:0; min-width:220px;
  background:#fff; color:#3B2F2F; border-radius:10px; padding:8px;
  box-shadow:0 10px 24px rgba(0,0,0,.18); display:none;
}
.submenu:hover > .dropdown{display:block}
.submenu .dropdown a{color:#3B2F2F; display:block; padding:8px 10px; border-radius:8px}
.submenu .dropdown a:hover{background:#efe4d3}


.banner{position:relative; overflow:hidden; height:clamp(280px,52vw,560px); background:#eee}
.banner img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:opacity .5s ease}
.banner-text{position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:0 14px}
.banner-text h1{color:#fff; text-shadow:0 8px 20px rgba(0,0,0,.45); font-size:clamp(22px,4vw,54px); margin:0 0 12px}
.btn{display:inline-block; padding:12px 22px; border-radius:12px; color:#fff; text-decoration:none; font-weight:800; box-shadow:0 8px 22px rgba(0,0,0,.25)}
.btn-brown{background:#59351F}.btn-green{background:#2c7a5b}.btn-orange{background:#FF7F00}


.categoria-scroll{width:min(96%,1200px); margin:28px auto}
.scroll-contenedor{display:flex; gap:14px; overflow-x:auto; padding:8px 4px; scroll-snap-type:x mandatory}
.scroll-contenedor .producto{flex:0 0 200px; background:#fff; border-radius:12px; box-shadow:0 6px 14px rgba(0,0,0,.08); padding:12px; scroll-snap-align:start; text-align:center}
.scroll-contenedor .producto h4{font-size:.95rem; font-weight:600; color:#2f2f2f; margin:10px 6px 4px; line-height:1.3; height:2.6em; overflow:hidden}

.productos-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.producto{background:#fff; border-radius:12px; box-shadow:0 6px 14px rgba(0,0,0,.08); padding:12px; text-align:center}
.producto img{width:100%; height:180px; object-fit:contain; background:#f7f3ef; border-radius:10px}
.producto h3{font-size:1rem; margin:10px 0 6px}
.producto .precio{font-weight:700; color:#59351F; margin-bottom:6px; display:inline-block}


.modal{position:fixed; inset:0; background:rgba(0,0,0,.55); display:none; z-index:9999}
.modal-contenido{background:#fff; margin:6% auto; padding:22px; border-radius:14px; width:min(92%,420px); text-align:center; position:relative; box-shadow:0 10px 30px rgba(0,0,0,.35)}
.cerrar-modal{position:absolute; top:8px; right:10px; font-size:24px; color:#777; cursor:pointer}


.review-widget{position:fixed; right:16px; bottom:16px; width:320px; max-height:64vh; overflow:auto; background:#fff; border-radius:14px; box-shadow:0 10px 28px rgba(0,0,0,.22); z-index:8888}
.review-widget.minimized{width:52px; height:44px; overflow:hidden; display:flex; align-items:center; justify-content:center}
.review-header{display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-bottom:1px solid #eee}
.review-list{padding:8px 10px}
.review-item{display:grid; grid-template-columns:48px 1fr; gap:10px; padding:10px; border-radius:10px; border:1px solid #eee; margin-bottom:10px; background:#fffdf9}


footer{background:#3B2F2F; color:#fff; padding:18px}
.footer-wrap{max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:14px}
.footer-left{display:flex; align-items:center; gap:10px}
.footer-left img{width:32px; height:32px; border-radius:6px; background:#fff}
.footer-right a{color:#fff; margin-left:12px; font-size:18px; text-decoration:none}


@media (max-width: 1024px){
  .productos-grid{grid-template-columns:repeat(3,1fr)}
}


@media (max-width: 768px){
  nav{gap:8px}
  .nav-toggle{display:inline-block}
  .nav-icons{margin-left:auto}

  .nav-menu{
    position:absolute; left:0; right:0; top:56px;
    background:#3B2F2F; flex-direction:column; gap:0; display:none; padding:8px 10px; border-bottom:1px solid rgba(255,255,255,.15)
  }
  .nav-menu.open{display:flex}
  .nav-menu > li > a{padding:10px 6px; display:block}

  .submenu > .dropdown{
    position:static; display:none; background:#2f2424; color:#fff; box-shadow:none; border-radius:10px; margin:4px 0 8px
  }
  .submenu.open-sub > .dropdown{display:block}
  .submenu .dropdown a{color:#fff}

  .productos-grid{grid-template-columns:repeat(2,1fr)}
  .banner{height:clamp(240px,55vw,420px)}
  .review-widget{right:10px; bottom:10px; width:92vw; max-width:360px}
  .footer-wrap{flex-wrap:wrap}
}


@media (max-width: 480px){
  .productos-grid{grid-template-columns:1fr}
  .producto img{height:160px}
  .scroll-contenedor .producto{flex:0 0 180px}
  .banner-text h1{font-size:clamp(20px,5.2vw,28px)}
}

html, body { width:100%; }
img, svg, video { max-width:100%; height:auto; }


footer { background:#3B2F2F; color:#fff; }




@media (max-width: 900px){
  .producto-detalle{
    flex-direction:column;
    align-items:center;
    gap:18px;
    padding:18px;
  }
  .producto-imagen img{
    width:100%;
    max-width:480px;
  }
  .producto-info{
    width:100%;
  }
}

@media (max-width: 768px){
  header{ position:sticky; top:0; z-index:1000; }
  .nav-menu{
    z-index: 1001;
  }

  body{ overflow-x:hidden; }
}


@media (hover: none) and (pointer: coarse){
  .submenu:hover > .dropdown{ display:none; } 
  .submenu.open-sub > .dropdown{ display:block; } 
}


@media (max-width: 640px){
  .scroll-contenedor .producto{ flex:0 0 170px; }
  .producto img{ height:160px; }
}


@media (max-width: 768px){
  .footer-bar, .footer-wrap{
    flex-direction:column;
    gap:10px;
    text-align:center;
  }
}
